美文网首页
Java面试题总结1

Java面试题总结1

作者: 浩亮亮亮亮 | 来源:发表于2017-03-21 23:15 被阅读0次

九种基本数据类型的大小,以及它们的封装类:

注:

1.int是基本数据类型,Integer是int的封装类,是引用类型。int默认值是0,而Integer默认值是null,所以Integer能区分出0和null的情况。一旦java看到null,就知道这个引用还没有指向某个对象,再任何引用使用前,必须为其指定一个对象,否则会报错。

2.基本数据类型在声明时系统会自动给它分配空间,而引用类型声明时只是分配了引用空间,必须通过实例化开辟数据空间之后才可以赋值

数组对象也是一个引用对象,将一个数组赋值给另一个数组时只是复制了一个引用,所以通过某一个数组所做的修改在另一个数组中也看的见。

Switch能否用string做参数?

Switch可以用整型,枚举类型,boolean,string类型做参数,但是不能用浮点型。

equals==的区别。

==操作比较的是两个变量的值是否相等,对于引用变量类型表示的是两个变量在堆中的地址是否相同,即栈中的内容是否相同。equals比较的是两个对象的内容。

Object有哪些公用方法

Object是所有类的父类,任何类都默认继承Object类。

Object类的方法:

1.getClass:final方法,获得运行时类型

2.equals:

3.notify()唤醒在此对象监视器上等待的单个线程。

4.notifyAll()唤醒在此对象监视器上等待的所有线程。

5.wait()在其他线程调用此对象的notify()方法或notifyAll()方法前,导致当前线程等待。

6.clone:保护方法,实现对象的浅复制,只有实现了Cloneable接口才能调用该方法,否则抛出CloneNotSupportedException异常。

Java里除了8中基本类型传参数都是值传递,其它类对象传参数都是引用传递,我们有时候不希望在方法里将参数改变,这就需要在类中复写clone方法。

浅复制与深复制

浅复制:被复制对象的所有变量都含有与原来对象相同的值,而所有的对其它对象的引用仍然指向原来的对象。换言之,浅复制仅仅复制所考虑的对象,而不复制它所引用的对象。

深复制:被复制的对象以及该对象所引用的其它对象都复制了一遍。

Java的四种引用,强弱软虚,以及它们用到的场景

参考:my.oschina.net/ydsakyclguozi/blog/404389

强引用:Object o = new Object(),这里o就是一个强引用。如果一个对象具有强引用,即使内存不足,也绝不会被垃圾回收器回收。如果不引用时,使o = null,或超出对象的生命周期范围,就会被gc回收。

软引用:如果一个对象只有软引用,当内存空间足够时,不会被gc回收,当内存空间不足时,会被gc回收。示例:

String str=new String("abc");//强引用

SoftReference softRef=newSoftReference(str);//软引用

弱引用:弱引用与软引用的区别在于:只具有弱引用的对象拥有更短的生命周期。在垃圾回收器线程扫描它所管辖的内存区域的过程中,一旦发现了只具有弱引用的对象,不管当前内存空间足够与否,都会回收它的内存。不过,由于垃圾回收器是一个优先级很低的线程,因此不一定会很快发现那些只具有弱引用的对象。

虚引用:“虚引用”顾名思义,就是形同虚设,与其他几种引用都不同,虚引用并不会决定对象的生命周期。如果一个对象仅持有虚引用,那么它就和没有任何引用一样,在任何时候都可能被垃圾回收器回收。

HashCode的作用:

HashCode的存在主要是为了查找的快捷性,HashCode是用来在散列存储结构中确定对象的存储地址的。如果两个对象的hashCode值不同,则这两个对象一定不同。

ArrayList、LinkedList和Vector的区别:


Collection继承图

LinkedList,ArrayList与Vector的比较:

这三个类都是基于数组实现的List类

LinkedList和ArrayList是线程不安全的,Vector是线程安全的,但是Vector性能差。

ArrayList是一个可改变大小的数组.当更多的元素加入到ArrayList中时,其大小将会动态地增长.内部的元素可以直接通过get与set方法进行访问,因为ArrayList本质上就是一个数组。

LinkedList是一个双链表,在添加和删除元素时具有比ArrayList更好的性能.但在get与set方面弱于ArrayList。

StringStringBufferStringBuilder的区别

String类是不可变类,任何String的改变都会产生一个新的String对象,而StringBuffer和StringBuilder都是可变类。StringBuffer支持并发操作,线程安全,适合多线程使用,StringBuilder不支持并发操作,线程不安全,不支持多线程使用,但StringBuilder速度更快。

MapSetListQueueStack的特点和用法

Map是使用键值对来存储数据,且一一映射,值可以重复,但是键不能。TreeMap可以保证顺序,HashMap则不行。

Set是不包含重复元素的集合,set最多包含一个null元素。

List是有序的可重复集合,可以再任意位置增加和删除元素。

Queue先进先出。

Stack后进先出。

使用建议:如果涉及堆栈,队列等操作,建议使用List;对于快速插入和删除元素的,建议使用LinkedList;如果需要快速随机访问元素的,建议使用ArrayList。

HashMapHashTable的区别:

HashMap可接受值为null,是不同步的,HashTable不能接受值为null,是同步的。

相关文章

网友评论

      本文标题:Java面试题总结1

      本文链接:https://www.haomeiwen.com/subject/xadnnttx.html