20110521

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;

     }

}

 

 

 

 

 


你可能感兴趣的:(xml,J#)