------ <a href="
http://www.itheima.com" target="blank">android培训</a>、<a href="
http://www.itheima.com" target="blank">java培训</a>、期待与您交流! ----------
总结一:比较
1 ,数组 (Array) ,数组类 (Arrays)
Java 所有“存储及随机访问一连串对象”的做法, array 是最有效率的一种。但缺点是容量固定且无法动态改变。 array 还有一个缺点是,无法判断其中实际存有多少元素, length 只是告诉我们 array 的容量。
Java 中有一个数组类 (Arrays) ,专门用来操作 array 。数组类 (arrays) 中拥有一组 static 函数。
equals() :比较两个 array 是否相等。 array 拥有相同元素个数,且所有对应元素两两相等。
fill() :将值填入 array 中。
sort() :用来对 array 进行排序。
binarySearch() :在排好序的 array 中寻找元素。
System.arraycopy() : array 的复制。
若编写程序时不知道究竟需要多少对象,需要在空间不足时自动扩增容量,则需要使用容器类库, array 不适用。
2 ,容器类与数组的区别
容器类仅能持有对象引用(指向对象的指针),而不是将对象信息 copy 一份至数列某位置。一旦将对象置入容器内,便损失了该对象的型别信息。
3 ,容器 (Collection) 与 Map 的联系与区别
Collection 类型,每个位置只有一个元素。
Map 类型,持有 key-value 对 (pair) ,像个小型数据库。
Collections 是针对集合类的一个帮助类。提供了一系列静态方法实现对各种集合的搜索、排序、线程完全化等操作。相当于对 Array 进行类似操作的类—— Arrays 。
如, Collections.max(Collection coll); 取 coll 中最大的元素。
Collections.sort(List list); 对 list 中元素排序
List , Set , Map 将持有对象一律视为 Object 型别。
Collection 、 List 、 Set 、 Map 都是接口,不能实例化。继承自它们的 ArrayList, Vector, HashTable, HashMap 是具象 class ,这些才可被实例化。
vector 容器确切知道它所持有的对象隶属什么型别。 vector 不进行边界检查。
总结二:需要注意的地方
1 、 Collection 只能通过 iterator() 遍历元素,没有 get() 方法来取得某个元素。
2 、 Set 和 Collection 拥有一模一样的接口。但排除掉传入的 Collection 参数重复的元素。
3 、 List ,可以通过 get() 方法来一次取出一个元素。使用数字来选择一堆对象中的一个, get(0)... 。 (add/get)
4 、 Map 用 put(k,v) / get(k) ,还可以使用 containsKey()/containsValue() 来检查其中是否含有某个 key/value 。
HashMap 会利用对象的 hashCode 来快速找到 key 。
哈希码 (hashing) 就是将对象的信息经过一些转变形成一个独一无二的 int 值,这个值存储在一个 array 中。我们都知道所有存储结构中, array 查找速度是最快的。所以,可以加速查找。发生碰撞时,让 array 指向多个 values 。即,数组每个位置上又生成一个梿表。
5 、 Map 中元素,可以将 key 序列、 value 序列单独抽取出来。
使用 keySet() 抽取 key 序列,将 map 中的所有 keys 生成一个 Set 。
使用 values() 抽取 value 序列,将 map 中的所有 values 生成一个 Collection 。
为什么一个生成 Set ,一个生成 Collection ?那是因为, key 总是独一无二的, value 允许重复。
总结三:如何选择
在各种 Lists ,对于需要快速插入,删除元素,应该使用 LinkedList (可用 LinkedList 构造堆栈 stack 、队列 queue ),如果需要快速随机访问元素,应该使用 ArrayList 。最好的做法是以 ArrayList 作为缺省选择。 Vector 总是比 ArrayList 慢,所以要尽量避免使用。
在各种 Sets 中, HashSet 通常优于 HashTree (插入、查找)。只有当需要产生一个经过排序的序列,才用 TreeSet 。 HashTree 存在的唯一理由:能够维护其内元素的排序状态。
在各种 Maps 中 HashMap 用于快速查找。
最后,当元素个数固定,用 Array ,因为 Array 效率是最高的。
进入黑马程序员,加油加油加油,。,。
------ <a href="http://www.itheima.com" target="blank">android培训</a>、<a href="http://www.itheima.com" target="blank">java培训</a>、期待与您交流! ----------
总结一:比较
1 ,数组 (Array) ,数组类 (Arrays)
Java 所有“存储及随机访问一连串对象”的做法, array 是最有效率的一种。但缺点是容量固定且无法动态改变。 array 还有一个缺点是,无法判断其中实际存有多少元素, length 只是告诉我们 array 的容量。
Java 中有一个数组类 (Arrays) ,专门用来操作 array 。数组类 (arrays) 中拥有一组 static 函数。
equals() :比较两个 array 是否相等。 array 拥有相同元素个数,且所有对应元素两两相等。
fill() :将值填入 array 中。
sort() :用来对 array 进行排序。
binarySearch() :在排好序的 array 中寻找元素。
System.arraycopy() : array 的复制。
若编写程序时不知道究竟需要多少对象,需要在空间不足时自动扩增容量,则需要使用容器类库, array 不适用。
2 ,容器类与数组的区别
容器类仅能持有对象引用(指向对象的指针),而不是将对象信息 copy 一份至数列某位置。一旦将对象置入容器内,便损失了该对象的型别信息。
3 ,容器 (Collection) 与 Map 的联系与区别
Collection 类型,每个位置只有一个元素。
Map 类型,持有 key-value 对 (pair) ,像个小型数据库。
Collections 是针对集合类的一个帮助类。提供了一系列静态方法实现对各种集合的搜索、排序、线程完全化等操作。相当于对 Array 进行类似操作的类—— Arrays 。
如, Collections.max(Collection coll); 取 coll 中最大的元素。
Collections.sort(List list); 对 list 中元素排序
List , Set , Map 将持有对象一律视为 Object 型别。
Collection 、 List 、 Set 、 Map 都是接口,不能实例化。继承自它们的 ArrayList, Vector, HashTable, HashMap 是具象 class ,这些才可被实例化。
vector 容器确切知道它所持有的对象隶属什么型别。 vector 不进行边界检查。
总结二:需要注意的地方
1 、 Collection 只能通过 iterator() 遍历元素,没有 get() 方法来取得某个元素。
2 、 Set 和 Collection 拥有一模一样的接口。但排除掉传入的 Collection 参数重复的元素。
3 、 List ,可以通过 get() 方法来一次取出一个元素。使用数字来选择一堆对象中的一个, get(0)... 。 (add/get)
4 、 Map 用 put(k,v) / get(k) ,还可以使用 containsKey()/containsValue() 来检查其中是否含有某个 key/value 。
HashMap 会利用对象的 hashCode 来快速找到 key 。
哈希码 (hashing) 就是将对象的信息经过一些转变形成一个独一无二的 int 值,这个值存储在一个 array 中。我们都知道所有存储结构中, array 查找速度是最快的。所以,可以加速查找。发生碰撞时,让 array 指向多个 values 。即,数组每个位置上又生成一个梿表。
5 、 Map 中元素,可以将 key 序列、 value 序列单独抽取出来。
使用 keySet() 抽取 key 序列,将 map 中的所有 keys 生成一个 Set 。
使用 values() 抽取 value 序列,将 map 中的所有 values 生成一个 Collection 。
为什么一个生成 Set ,一个生成 Collection ?那是因为, key 总是独一无二的, value 允许重复。
总结三:如何选择
在各种 Lists ,对于需要快速插入,删除元素,应该使用 LinkedList (可用 LinkedList 构造堆栈 stack 、队列 queue ),如果需要快速随机访问元素,应该使用 ArrayList 。最好的做法是以 ArrayList 作为缺省选择。 Vector 总是比 ArrayList 慢,所以要尽量避免使用。
在各种 Sets 中, HashSet 通常优于 HashTree (插入、查找)。只有当需要产生一个经过排序的序列,才用 TreeSet 。 HashTree 存在的唯一理由:能够维护其内元素的排序状态。
在各种 Maps 中 HashMap 用于快速查找。
最后,当元素个数固定,用 Array ,因为 Array 效率是最高的。
进入黑马程序员,加油加油加油,。,。
------ <a href="http://www.itheima.com" target="blank">android培训</a>、<a href="http://www.itheima.com" target="blank">java培训</a>、期待与您交流! ----------