小白学java第40天
1.存放的元素是键值对:即K-V
2. hashtable的键和值都不能为null,否则会抛出NullPointerException
3.hashTable使用方法基本上和HashMap一样
4.hashTable是线程安全的(synchronized), hashMap是线程不安全的
Properties:
1. Properties类继承自Hashtable类并且实现了Map接口,也是使用一种键值对的形式来保存数据
2.使用特点和Hashtable类似
如何选择集合实现类:
1.先判断存储的类型(一组对象[单列]或一组键值对[双列])
2.一组对象[单列:Collection]
允许重复:List
增删多:LinkedList[底层维护了一个双向链表]
改查多:ArrayList [底层维护Object类型的可变数组]
不允许重复:Set
无序:HashSet[底层是HashMap,维护了一个哈希表即(数组+链表+红黑树)
排序:TreeSet
插入和取出顺序一致:LinkedHashSet,维护数组+双向链表
3.一组键值对: Map
键无序: HashMap [底层是:哈希表 jdk7:数组+链表,jdk8:数组+链表+红黑树]
键排序:TreeMap
键插入和取出顺序一致:LinkedHashMap
读取文件:Properties