1.java语法题
1.java的合法变量、
private String a;
private String a_;
private String a_0_;
// private String 2a;// illegal 违法的
private String $;
// private String a.b;//illegal 违法的
private String aa$;
private String a2$;
private String a_a$;
2.
public static void main(String[] args) {
int j = 0;
for (int i = 0; i < 100; i++) {
j = j++;
}
System.out.println("jj----->" + j);
}
输出 :
jj----->0
3.
public static void main(String[] args) {
ValidVariable var = new ValidVariable();
var.setA(var);//1
System.out.println("var.a --->" + var.getA());
}
public void setA(ValidVariable var)//2 {
ValidVariable var1 = new ValidVariable();//3
var.setA("abc");//4
var1.setA("cba");//5
var = var1;//6
}
输出:
var.a --->abc
解析:
对象的传输是传址(实质也是传值,只不过该值为地址)
1处把main非法里的对象var的地址传入2处
在4处对main传进来的对象地址所对应进行赋值 a-->abc
3处为新建一个变量,在5处对其变量赋值a-->cba
6处把setA方法里的变量var 的值改为var1
注意这里的变量作用范围:
setA中var 变量只能在setA方法中起作用,对main方法中的var变量的值不会造成影响。
问答题:
1.String和StringBuffer和StringBuilder的区别
String 表示不可更改的字符序列。
StringBuffer 表示一个可以更改的字符序列,可对其进行增加和修改,同时它是线程安全的,支持同步
StringBuilder基本和StringBuffer基本无异,StringBuilder是线程不安全的。
2.ArrayList,Vector和LinkedList的区别,性能有说明差别
1.ArrayList和Vector内部实现基本无多大差异,区别是Vector的线程安全的,其内部实现采用数组存储数据,
所以查询数据较快,但增删数据较慢,涉及数据移动的内存操作。
而LinkedList是连接的方式存储数据,通过数据之间的前后关联保存数据,这种方式增删数据快,只需维护数据对应关系即可,但查找数据较慢,必须从链接列表的两端开始查找数据。
3.HashMap和HashTable的区别
1.HashMap是线程不安全的HashTable是线程安全的。
2.HashMap和HashTable父类不同
3.HashMap与HashTable的hashCode方法实现不同
4.java中对xml的处理方式有几种,它们也说明差异
1.Dom4j,Sax,java.xml
Dom4j在解析xml文档时会整个文档数据加入内存,所以不适用于数据量很大的xml文档,但对xml里的数据操作会很快。
Sax是以事件驱动的方式解析xml文档,使用处理数据量大的xml文档,但在获得xml数据上比Dom4j要慢
5.写一个线程安全的单实例
public class Singleton {
private Singleton single = new Singleton();
private Singleton(){}
public Singleton newInstance(){
return single;
}
}