目录
6、ArrayList ,Vector和LinkedList的区别
7、HashMap,Hashtable,TreeMap和WeakHashMap区别
10、String str = new String("abc")创建实例的过程
1、java语言的优点?
面向对象/平台无关性/内置类库/支持web应用开发/具有较好的安全性和健壮性。
2、java与c/c++异同?
- java解释性语言,c/c++编译型语言。
- java中没有指针。
- c/c++兼具面向过程和面向过程编程的特点,可以定义全局变量和全局函数。
- java不支持多继承。
- c/c++需要开发人员去管理对内存的分配,包括申请和释放。java不需要。
3、java程序初始化的顺序是怎样的?
父类静态变量->父类静态代码块-> 子类静态变量->子类静态代码块->父类非静态变量->父类非静态代码块->父类构造函数->子类非静态变量->子类非静态代码块->子类构造函数。
4、java中的作用域
成员变量:
作用域 | 当前类 | 同一package | 子类 | 其他package |
private | √ | |||
default | √ | √ | ||
protected | √ | √ | √ | |
public | √ | √ | √ | √ |
静态变量:
用static修饰的成员变量被称为静态变量或者全局变量。只要一个类被加载,JVM就会给类的静态变量分配内存空间。
局部变量:
由其所在的花括号决定。
5、java中使用clone()方法的步骤
继承Cloneable接口。
在类中重写Object类中的clone()方法。
在clone方法中调用super.clone()。
把浅复制的引用指向原型对象新的克隆体。
若需要深复制:需要将对象中的非基本类型的属性也调用clone()方法完成深复制。
例子:o.atrr=this.getAttr().clone(),最后返回o
6、ArrayList ,Vector和LinkedList的区别
- ArrayList和Vector都是基于存储元素的数组来实现的,内存中开辟连续的空间,所以对数据的索引比较快,插入比较慢。
- 它们都有一个默认的初始化容量,如果超过需要扩容,ArrayList默认扩充为原来的1.5倍,Vector默认扩充为原来的2倍。
- Vector是线程安全的,ArrayList不是线程安全的。
- LinkedList是采用双向列表来实现的,所以对数据的索引比较慢,插入比较快。它是非线程安全的 。
7、HashMap,Hashtable,TreeMap和WeakHashMap区别
- 父类不同:HashMap的父类是AbstractMap,Hashtable的父类是Dictionary,二者都实现了Map接口。
- 线程安全性:HashMap不是线程安全的,Hashtable是线程安全的。
- contains方法:HashMap把Hashtable的contains方法去掉了。
- key-value:hashmap允许空键值,hashtable不允许。
- 遍历方式:hashmap使用Iterator,hashtable使用Enumeration。
- hash值不同:hashtable直接使用hashcode。hashmap需要计算。先求与运算,然后模取长度。
- 默认值与扩容方式:hashtable数组默认为11,增加的方式为old*2+1;hashmap数组默认为16,而且一定是2的指数。
- TreeMap实现了SortMap接口,根据键进行排序。
- WeakHashMap采用弱引用。只要key不在被外部使用,他就可以被垃圾回收器回收。
8、 List,Map和Set的区别:
是否有顺序 | 值是否可重复 | |
List | 有 | 可以 |
Map | 没有 | 键不可以,值可以 |
Set | 没有 | 不可以 |
9、反射机制
JAVA反射机制是在运行状态中,对于任意一个实体类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它
的任意方法和属性;这种动态获取信息以及动态调用对象方法的功能称为java语言的反射机制。
如何获取Class类?
Class.forName(classname) 用于做类加载
obj.getClass() 用于获得对象的类型
类名.class 用于获得指定的类型,传参用
10、String str = new String("abc")创建实例的过程
首先在堆中创建一个对象放入"abc",并且str指向该对象,
在字符串常量池中寻找是否有字符串"abc",
若有,将new出来的字符串与常量字符串对象联系起来;
若没有,在字符串常量池中创建一个字符串为"abc"的对象,然后将new出来(堆中)的字符串联系起来。