List集合 具体实现包括 ArrayList 和 Vector ,它们是 可变大小的列表,比较适合构建,存储和操作任何类型对象的元素列表.List 适用于按 数值索引访问元素的情形.
List 和 Set 的异同点: 它们都可以迭代出所有元素,迭代时先要得到一个iterator 对象,所以,set 和List 类都有一个Iterator 方法,用于返回那个 iterator 对象.map 可以返回三个集合,一个是返回所有的key 的集合,另外一个返回
的是所有 value 的集合,再一个返回的key 和 value组合成的EntrySet 对象的集合, map 也有
get 方法,参数是 key,返回值是 key 对应的 value;\
HashMap 和 hashTable 的区别!
HashMap 是 HashTable 的轻量级实现(非线程安全的实现),它们都完成了Map 接口,主要区别在于HashMap
是 允许空(null) 键值(key),由于非线程安全,在只有一个线程访问的情况下,效率要高于Hashtable ;
HashMap 允许将 null 作为一个entry 的key 或者 value,而 Hashtable 不允许. HashMap 把 Hashtable
的 contains 方法去掉了,改成 containsvalue 和 containsKey,因为 contains 方法容易让人引起误解;
Hashtable 继承自 Dictionary 类,而 HashMap 是 Java1.2 引进的Map interface 的一个实现.
最大的不同是,Hashtable的方法Synchronize的,而HashMap 不是,在多个线程访问Hashtable 时,不需要自己为它的方法实现同步,而 HashMap 就必须为之提供外同步.
Hashtable 和HashMap 采用的Hash/Rehash算法 都大概一样,所以性能不会有很大的差异.
就HashMap 与 HashTable 主要从三方面来说;
一: 历史原因:Hashtable是基于陈旧的Dictionary 类的,HashMap 是 Java 1.2 引进的Map 接口的一个实现;
二:同步性:Hashtable 是线程安全的,也就是说是同步的,而HashMap 是线程不安全的,不是同步的
三: 只有 HashMap 可以让你将空值作为一个表的条目的key 或 value;
|