java jdk常见问题总结,Java常见问题总结

1、Object有哪些公共方法?

答:clone(),equals(),hashCode(),wait(), getClass(),finalize(),notify(),notifyAll(),toString()

2、Object中finalize()的作用?

答:用于清理。finalize()方法不需要显示地调用, 在垃圾回收(GC)时会被自动先行调用的。

3、Java中四种引用方式?

答:http://my.oschina.net/eager/blog/726428

4、hashCode()的作用?

答:hashcode是jdk根据对象的地址或者字符串或者数字算出来的int类型的数值。

在 Java 应用程序执行期间,在对同一对象多次调用 hashCode()时,必须一致地返回相同的整数,前提是将对象进行hashCode()比较时所用的信息没有被修改。

如果两个对象根据hashCode()返回的整数值不等,则equals()得到的结果必定为false;

如果两个对象根据equals()比较是相等的,那么调用两个对象的hashCode()必须返回相同的整数结果;

如果两个对象根据equals()比较是不等的,则hashCode()不一定得返回不同的整数。

详见:http://www.cnblogs.com/dolphin0520/p/3681042.html

5、ArrayList、LinkedList、Vector的区别?

线程安全性:

Vector、Stack:线程安全

ArrayList、LinkedList:非线程安全

实现方式:

LinkedList:双向链表

ArrayList,Vector,Stack:数组

扩容方式:

Stack继承自Vector,故不分开解释。

ArrayList扩容原来的50%(int newCapacity = (oldCapacity * 3)/2 + 1)

Vector缺省情况是原来的1倍(newCapacity  = oldCapacity * 2)

其他详见:http://blog.csdn.net/a19881029/article/details/45533733

6、String、StringBuffer与StringBuilder的区别?

String类为final类型

StringBuffer线程安全的可变字符序列

StringBuilder线程不安全,JDK5.0新增

在构造 StirngBuffer 或 StirngBuilder 时应尽可能指定它们的容量。如果操作的字符串长度(length)不超过 16 个字符就不用了,缺省时默认构造一个容量为16的对象,否则不指定会降低性能

详见:http://blog.csdn.net/kingzone_2008/article/details/9220691

7、java.io 与 java.nio的区别?

主要区别如下表:

IO

NIO

面向流

面向缓冲

阻塞IO

非阻塞IO

选择器

详见:http://my.oschina.net/eager/blog/729320

8、HashMap和Hashtable(注意 t 是小写的)的区别?

Hashtable是基于陈旧的Dictionary类的,HashMap是Java 1.2引进的Map接口的一个实现;

Hashtable是线程安全的,HashMap是线程不安全的;

HashMap允许null作为Entry的key和value,Hashtable不允许;

Hashtable使用Enumeration,HashMap使用Iterator遍历;

Hashtable中hash数组默认大小是11,扩容的方式是 old*2+1,HashMap中hash数组的默认大小是16,扩容一定是2的指数。

9、HashMap和ConcurrentHashMap的区别?

HashMap是since JDK1.2,ConcurrentHashMap是since JDK1.5;

HashMap是线程不同步的,ConcurrentHashMap是线程同步的;

HashMap本质是数组+链表,ConcurrentHashMap将数据分为多个segment,默认16个。

ConcurrentHashMap详见:http://www.cnblogs.com/dolphin0520/p/3932905.html

ConcurrentHashMap实现同步分析:http://blog.csdn.net/xuefeng0707/article/details/40834595

10、Hashtable和ConcurrentHashMap的区别?

Hashtable采取的是synchronized整个方法,ConcurrentHashMap采取的是synchronized代码块

Hashtable每次同步锁整体,ConcurrentHashMap只锁当前需要用到的segment

更多关于Map的详见:http://my.oschina.net/eager/blog/729795

11、try{}里有一个return语句,finally{}里的代码还会执行吗?

会执行,在return之前执行。

public class Test {

public static void main(String[] args) {

int a = 1;

System.out.println("a:"+a);

System.out.println("result:"+getNum(a));

}

public static int getNum(int a) {

try {

a = 2;

System.out.println("try-a:"+a);

return a;

} finally {

a = 3;

System.out.println("finally-a:"+a);

}

}

}

结果展示:

e4c7e95a18d0a43e274c49c16d6903a5.png

可能会觉得很疑惑,从输出可以看出是执行了finally中的语句,但为什么最终返回值是2。因为如果存在finally代码块,try中的return语句不会立马返回调用者,而是记录下返回值待finally代码块执行完毕之后再向调用者返回其值,所以在finally块中调用return,则会修改返回值,但是不建议这样做。

12、Excption与Error包结构?

ee4024450ba3efd4366dd6ad2c4580eb.png

13、OOM你遇到过哪些情况?SOF你遇到过哪些情况?

OOM(Out Of Memory):当JVM因为没有足够的内存来为对象分配空间并且垃圾回收器也已经没有空间可回收时,就会抛出这个Error(注:非Exception,因为这个问题已经严重到不足以被应用处理)。

1)分配的少了,比如虚拟机本身可使用的内存(一般通过启动时的JVM参数指定)太少。

2)应用用的太多,并且用完没释放,浪费了,此时就会造成内存泄露或者内存溢出。

内存泄露:申请使用完的内存没有释放,导致虚拟机不能再次使用该内存,此时这段内存就泄露了,因为申请者不用了,而又不能被虚拟机分配给别人用。

内存溢出:申请的内存超出了JVM能提供的内存大小,此时称之为溢出。

常见内存溢出情况:

java.lang.OutOfMemoryError: Java heap space ------>java堆内存溢出,此种情况最常见,一般由于内存泄露或者堆的大小设置不当引起。对于内存泄露,需要通过内存监控软件查找程序中的泄露代码,而堆大小可以通过虚拟机参数-Xms,-Xmx等修改。

java.lang.OutOfMemoryError: PermGen space ------>java永久代溢出,即方法区溢出了,一般出现于大量Class或者jsp页面,或者采用cglib等反射机制的情况,因为上述情况会产生大量的Class信息存储于方法区。此种情况可以通过更改方法区的大小来解决,使用类似-XX:PermSize=64m -XX:MaxPermSize=256m的形式修改。另外,过多的常量尤其是字符串也会导致方法区溢出。

SOF(Stack Over Flow):JAVA虚拟机栈溢出,一般是由于程序中存在死循环或者深度递归调用造成的,栈大小设置太小也会出现此种溢出。可以通过虚拟机参数-Xss来设置栈的大小。

详见:http://www.cnblogs.com/gaojing/archive/2012/10/30/2844938.html

未完待续,该博客会每一天进行更新。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值