201606中通笔试题

1、ArrayList和Vector的区别?HashMap和HashTable的区别?

1)、Vector的方法都是同步的(synchronized),是线程安全的;而ArrayList不是。由于线程同步必然影响性能,因此ArrayList的性能优于Vector。

2)、当Vector和ArrayList的大小超过初始大小,Vector会自动将容量翻倍,而ArrayList会增加50%,因此,ArrayList会更加节省内存。

HashMap和HashTable一样,HashTable是同步的。

扩展:ArrayList的LinkedList的区别?

ArrayList的内部实现是

基于内部数组Object[],所以从概念上讲它跟像一个数组;

LinkedList基于一组连接的记录,所以它更像一个链表结构,

因此在性能上它们有很大的差别:在ArrayList的前面和中间插入数据时,必须将其后的数据全部后移,这样必然发费较

多的时间,所以,当你在后面添加数据而不是前面或中间,并且需要随机的访问其中元素时,使用ArrayList会提供比较

好的性能;而访问链表的某个元素时,就必须从链表的一端沿着连接方向一个一个元素查找,知道找到所需元素为止,

因此:当你的操作是在一组数据的前面或中间插入或删除某个数据时,并且按照顺序访问其中元素,就用LinkedList。

2、Collection和Collections的区别?

java.util.Conllection是一个集合接口,Collection在java类库中有很多具体的实现类。Collection接口的意义是各种具体的集合提供最大化的统一操作方式。

<span style="font-size:18px;">Collection
	--List
		--ArrayList
		--Vector
		--LinkedList
	--Set</span>

java.util.Conllecions是一个包装类,提供了有关集合操作的静态多态方法。因此此类不能实例化。就像一个工具类,服务于java.util.Collection框架。

<span style="font-size:18px;">import java.util.ArrayList;  
import java.util.Collections;  
import java.util.List;  
  
public class TestCollections {  
      
    public static void main(String args[]) {  
        //注意List是实现Collection接口的  
        List list = new ArrayList();  
        double array[] = { 112, 111, 23, 456, 231 };  
        for (int i = 0; i < array.length; i++) {  
            list.add(new Double(array[i]));  
        }  
        Collections.sort(list);  
        for (int i = 0; i < array.length; i++) {  
            System.out.println(list.get(i));  
        }  
        // 结果:23.0 111.0 112.0 231.0 456.0  
    }  
}  </span>

3、String s = new String("xyz");创建了几个String Object对象。

2个;new String(),"xyz"。







  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值