本文参考多处,一并感谢!
http://www.blogjava.net/fanyingjie/archive/2007/06/27/126467.aspx
http://baike.baidu.com/view/1788559.htm
http://honda418.iteye.com/blog/315893
http://jeff-tang.blog.163.com/blog/static/141686909201022010522906/
http://www.cnblogs.com/mgod/archive/2007/08/05/844011.html
参考过的书籍
《深入理解Java虚拟机:JVM高级特性与最佳实践》
12.ArrayList,Vector,LinkedList的区别
ArrayList Vector LinkedList 实现原理 数组 数组 双向链表 线程安全 否 是 否 优点 1.数组实现优于遍历
2.非线程安全,效率较高1.数组实现优于遍历
2.线程安全1.节点的增删无需对象的重建
2.空间利用毫无浪费缺点 1.非线程安全
2.数组中未使用元素照成了空间的浪费
3.扩容可能引起对象的重建
4.增删有可能引起数组元素的移动1.数组中未使用的元素造成空间的浪费
2.扩容可能引起对象的重建
3.线程安全,效率相对低
4.增删有可能引起数组元素的移动1.遍历效率较低
2.非线程安全扩容 0.5倍增量 1倍增量 按需增删 使用场景 1.无线程的要求。
2.遍历较多,增删较少1.有线程安全的要求
2.遍历场景较多,增删场景较少增删场景较多的时候
11.int与Integer的区别
int Integer 类型 基本类型 复合类型 默认值 0 null 存储 栈(局部变量)
堆(成员变量,有待进一步确认)堆上(只能通过new创建) 方法 基本类型无方法 有 速度 快(栈上 的操作相对快) 慢 泛型支持 否(java中的泛型不支持,C++中的模板支持) 支持 容器类支持 否(直接使用通常会进行装箱操作) 支持 存在意义 1.历史原因(顺延C/C++中存在)
2.方便快速(无需new)基本类型int的包装类
提供了对泛型,容器类的支持
9.向一个List<Integer>的容器里放入String对象
需要了解的一些知识
实现代码
- Java中的泛型是伪泛型。(可参见周志明的《深入理解Java虚拟机:JVM高级特性与最佳实践》)
- 泛型是编译器的语法糖,并非产生了实际类型List<Integer>。
- 对于List<Integer>和List<String>都是在编译之后,都是作为List<Object>类型来使用的。
- 在Java虚拟机中,没有泛型的概念。
- 通过反射可以把一些强制性的检查推迟到运行期。
- 如果直接向List<Integer>中插入String对象,肯定会得到编译器的检查,并提示错误。
- 而反射机制可以把这种错误的检查延迟到运行期。(这是反射的一个缺点,会把编译期能够检查到的问题,推迟到了运行期发现)
- 由于List<Integer>对象在运行期,本身就是以List<Object>的形式存在,故其在运行期不会产生错误。
- 反射机制,通过编译期的检查骗过了我们。而我们又可以通过反射骗过了编译器的检查。
- package com.jue.test;
- import java.lang.reflect.InvocationTargetException;
- import java.lang.reflect.Method;
- import java.util.ArrayList;
- import java.util.List;
- public class TestMain {
- List<Integer> mIntList = new ArrayList<Integer>();
- public static void main(String[] args) throws SecurityException,
- NoSuchFieldException, IllegalArgumentException,
- IllegalAccessException, InvocationTargetException,
- NoSuchMethodException {
- TestMain tm = new TestMain();
- Method addMethod = List.class.getMethod("add",
- new Class[] { Object.class });
- //使用反射,我们避免了编译期的强制检查
- addMethod.invoke(tm.mIntList, new Object[] { new String("abc") });
- addMethod.invoke(tm.mIntList, new Object[] { new String("123") });
- addMethod.invoke(tm.mIntList, new Object[] { new String("cde") });
- addMethod.invoke(tm.mIntList, new Object[] { new String("fgh") });
- for (Object o : tm.mIntList) {
- System.out.println(o);
- }
- }
- }
输出结果:
abc
123
cde
fgh
10.List<Integer>与List<String>在编译后都是List<Object>形式存在
- package com.jue.test;
- import java.util.List;
- public class TestMain {
- public void testList(List<Integer> list) {
- }
- public void testList(List<String> list) {
- }
- }
结果:编译失败!分析:
- 如上所述,Java的泛型是编译器的语法糖,在编译后,统一使用List<Object>代替。
- 对于重载,方面名相同,而签名不同,由于参数都将是List<Object>,故编译失败,因为不可能产生签名一样的两个方法。
1.short转换相关的
其一,
- package com.jue.test;
- public class TestMain {
- public static void main(String args[]){
- short s1 = 1;
- s1 = s1 + 1;
- }
- }
Description ResourcePathLocationType
Type mismatch: cannot convert from int to short
TestMain.java /TestShort/src/com/jue/testline 6Java Problem
分析:
s1+1会自动转换成int类型,导致s1= s1+1;损失精度。
其二,
- package com.jue.test;
- public class TestMain {
- public static void main(String args[]){
- short s2 = 2;
- s2 += 2;
- }
- }
分析:
反编译之后
- package com.jue.test;
- public class TestMain
- {
- public static void main(String[] args)
- {
- short s2 = 2;
- s2 = (short)(s2 + 2);
- }
- }
2.RuntimeException与普通异常,error的区别。
Checked Exception:在编译时就能够被Java编译器所检测到的。
UncheckedException:则是编译时,java编译器不能检查到。
RuntimeException | 普通Exception | Error | |
受控异常 | 否 | 是 | 否 |
产生原因 | 开发者的编程错误 | 由于外界环境所限, 本身潜在的一些问题 |
Java运行时的系统错误,资源耗尽,是一种严重的, 程序无法修复的问题 |
例子 | NullPointerException ArrayOutOfIndexException ClassCastException ArithmeticException UnsupportedOperationException |
ClassNotFoundException IOException FileNotFoundException |
VirtualMachineError StackOverflowError OutOfMemoryError |
3.finally的一个面试题
- package com.jue.test;
- import java.util.ArrayList;
- import java.util.List;
- public class TestMain {
- public static void main(String[] args) {
- test();
- }
- private static void test() {
- List list = new ArrayList();
- try {
- System.out.println("return!!");
- return;
- } catch (Exception e) {
- System.out.println("catch Exception !!");
- } finally {
- System.out.println("finally!!");
- }
- }
- }
结果:
return!!
finally!!
分析:即便在try中return;finally总会被执行的意义不变,仍然会执行。
4.final,finalize,finally的区别
final:关键字,表不变
修饰:
- 方法:方法不可Override
- 类:不可被继承
- 基本类型量:常量,值不可变
- 符合类型量:引用不可变,即引用的值不可变
- final Object o1 = new Object();
- o1 = new Object();
finally:关键字,Java异常处理机制的一部分,在异常发生时,用来提供一个必要的清理的机会。
finalize:Object类的方法(参考自百度百科)
意义:Java技术允许使用finalize()方法在垃圾回收器将对象回收之前,做一些必要的清理操作。
调用前提:这个对象确定没有被引用到。
工作原理:
- 垃圾收集器准备好释放对象占用的空间。
- 首先调用其finalize方法。
- 下一次垃圾收集过程中,真正回收内存。
不确定性:
- finalize的执行时间是不缺定的。
- 一个对象引用另一个对象,并不能保证finalize的方法按照特定的执行顺序。
5.Override,Overload
Override Overload 签名+返回值 相同 方法名相同,签名不同 关系 父子类继承关系 通常是同一类层次中 识别 运行时多态
根据具体的对象,
查询对象的虚方法表,确定调用关系编译时多态
由对象的外观类型(即声明类型)决定修饰符限制 非private
非static
非final无特别 异常关系 子类方法不能抛出被父类方法更多的异常 无特别 可见性关系 子类不能比父类访问权限更窄
(里氏替换原则决定)无特别
6.Collection Collections
Collection:接口,集合类的接口,一个契约,提供了集合基本的大小,添加,清除,遍历方法等。
Collections:工具类,提供了很多静态方法,给集合提供一些查询,比较,排序,交换,线程安全化等方法。
7.Integer 缓存
- package com.jue.test;
- public class TestMain {
- public static void main(String[] args) {
- Integer i1 = 1;
- Integer i11 = 1;
- System.out.println(i1 == i11);
- Integer i2 = 200;
- Integer i22 = 200;
- System.out.println(i2 == i22);
- }
- }
结果 :
true
false
分析:反编译结果为
- package com.jue.test;
- import java.io.PrintStream;
- public class TestMain
- {
- public static void main(String[] args)
- {
- Integer i1 = Integer.valueOf(1);
- Integer i11 = Integer.valueOf(1);
- System.out.println(i1 == i11);
- Integer i2 = Integer.valueOf(200);
- Integer i22 = Integer.valueOf(200);
- System.out.println(i2 == i22);
- }
- }
可以看出,对于Integer i = 1;编译器做了额外的处理,即Integer.valueof();
Integer source code
- public static Integer valueOf(int i) {
- assert IntegerCache.high >= 127;
- if (i >= IntegerCache.low && i <= IntegerCache.high)
- return IntegerCache.cache[i + (-IntegerCache.low)];
- return new Integer(i);
- }
可以看出Integer对于一定 范围内的数字从Cache中取得,对于额外的,调用new创建。
IntegerCache源码如下:
故可以知道Integer的大小,默认是从-128到127,对于这个范围内的数组做了缓存的处理。
- private static class IntegerCache {
- static final int low = -128;
- static final int high;
- static final Integer cache[];
- static {
- // high value may be configured by property
- int h = 127;
- String integerCacheHighPropValue = sun.misc.VM
- .getSavedProperty("java.lang.Integer.IntegerCache.high");
- if (integerCacheHighPropValue != null) {
- int i = parseInt(integerCacheHighPropValue);
- i = Math.max(i, 127);
- // Maximum array size is Integer.MAX_VALUE
- h = Math.min(i, Integer.MAX_VALUE - (-low));
- }
- high = h;
- cache = new Integer[(high - low) + 1];
- int j = low;
- for (int k = 0; k < cache.length; k++)
- cache[k] = new Integer(j++);
- }
- private IntegerCache() {
- }
- }
8.sleep方法和wait方法的区别
wait sleep 所属类 Object Thread 意义 让线程挂起 让线程休眠指定的时间 释放锁 是 否(这个跟锁本来就没有关系) 恢复 1.有参:wait指定时间
2.无参:等待其他线程notify1.根据参数长度自动恢复。
2.异常打断使用限制 wait,notify必须持有当前对象锁的情况下调用 无特别 抛出异常 否 是 静态方法 否 是