学习笔记(八)对象的集合(二)
2015-07-29 15:38
246 查看
《Java编程思想》整理的一些学习笔记,有不对的地方,欢迎指出。
1.Java2 容器类类库的用途是“保存对象”,并将其划分为两个不同的概念:1)Collection。一组独立的元素,通常这些元素都服从某种规则。List 必须保持元素特定的顺序,即按照对象进入的顺序,而Set不能有重复的元素,使用自己内部的排序方法。2)Map。一组成对的“键值对”对象,也就是关联数组。Map可以返回其所有键组成的Set,其所有值组成的Collection,或其键值对组成的Set;并且可以扩展为多维Map(像多维数组一样),只要让键值对中的“值”是一个Map即可。如果添加元素的顺序对你很重要,应该使用LinkedHashSet或者LinkedHashMap。
2.Collections类像Arrays类一样,也有一些static方法,其中包括fill()。此fill()方法也是只复制同一个对象引用来填充整个容器的。
3.使用Java容器有个“缺点”,在将对象加入容器的时候就丢失了类型信息。因为如果容器只能保存你自己的类型,就失去了作为通用工具的意义。所以容器只保存对Object的引用,Object是所有类的基类,因此容器可以保存任何类型的对象(当然不包括基本类型,它们不是真正的对象)。所以在使用容器中的元素时,需要进行类型转换。
4.对于初学者,可以将ArrayList看作是“能够自动扩展的数组”。ArrayList用起来很方便:创建一个ArrayList,使用add()添加对象,使用get()和索引取出对象——就像数组那样,只是不实用方括号。ArrayList也有size()方法,通过它可以知道容器中有多少个元素,以免超过边界而引发异常。
5.从ArrayList容器中取元素使用,需要向下转型到具体类型,格式:(Class)list.get(i),这取出来的是具体类对象的引用,然后可以调用该类中的属性和方法,当然有一种特殊情况下可以不用向下转型,就是String。类中还有重写的toString()方法,直接输出list.get(i),会隐式的调用toString()方法,程序可以运行,不过当在toString()方法中使用this简写时,容易产生递归。
6.之前说ArrayList不能保存类型信息,其实可以通过ArrayList生成一个新的类,它只接受和返回指定的类型:
这样 MouseList类就做到了只接受和返回Mouse类型的对象。
7.迭代器(Iterator)可以达成不用重写代码就可以应用于不同类型的容器。它是一个对象,工作是遍历并选择序列中的对象,用途:
1) 使用方法iterator()要求容器返回一个Iterator。第一次调用Iterator的next()方法时,它返回序列的第一个元素。注意:iterator()方法是java.lang.Iterable接口,被Collection继承。
2) 使用next()获得序列中的下一个元素。
3) 使用hasNext()检查序列中是否还有元素。
4) 使用remove()将迭代器新返回的元素删除。
通过使用迭代器遍历整个序列,就不必为容器中的元素数量操心了,因为它的hasNext()和next()方法已经帮你解决。
1.Java2 容器类类库的用途是“保存对象”,并将其划分为两个不同的概念:1)Collection。一组独立的元素,通常这些元素都服从某种规则。List 必须保持元素特定的顺序,即按照对象进入的顺序,而Set不能有重复的元素,使用自己内部的排序方法。2)Map。一组成对的“键值对”对象,也就是关联数组。Map可以返回其所有键组成的Set,其所有值组成的Collection,或其键值对组成的Set;并且可以扩展为多维Map(像多维数组一样),只要让键值对中的“值”是一个Map即可。如果添加元素的顺序对你很重要,应该使用LinkedHashSet或者LinkedHashMap。
2.Collections类像Arrays类一样,也有一些static方法,其中包括fill()。此fill()方法也是只复制同一个对象引用来填充整个容器的。
3.使用Java容器有个“缺点”,在将对象加入容器的时候就丢失了类型信息。因为如果容器只能保存你自己的类型,就失去了作为通用工具的意义。所以容器只保存对Object的引用,Object是所有类的基类,因此容器可以保存任何类型的对象(当然不包括基本类型,它们不是真正的对象)。所以在使用容器中的元素时,需要进行类型转换。
4.对于初学者,可以将ArrayList看作是“能够自动扩展的数组”。ArrayList用起来很方便:创建一个ArrayList,使用add()添加对象,使用get()和索引取出对象——就像数组那样,只是不实用方括号。ArrayList也有size()方法,通过它可以知道容器中有多少个元素,以免超过边界而引发异常。
5.从ArrayList容器中取元素使用,需要向下转型到具体类型,格式:(Class)list.get(i),这取出来的是具体类对象的引用,然后可以调用该类中的属性和方法,当然有一种特殊情况下可以不用向下转型,就是String。类中还有重写的toString()方法,直接输出list.get(i),会隐式的调用toString()方法,程序可以运行,不过当在toString()方法中使用this简写时,容易产生递归。
6.之前说ArrayList不能保存类型信息,其实可以通过ArrayList生成一个新的类,它只接受和返回指定的类型:
public class MouseList{ private List list = new ArrayList(); public void add(Mouse m){ list.add(m); } publlic Mouse get(int index){ return (Mouse)list.get(index); } public int size(){ return list.size(); } }
这样 MouseList类就做到了只接受和返回Mouse类型的对象。
7.迭代器(Iterator)可以达成不用重写代码就可以应用于不同类型的容器。它是一个对象,工作是遍历并选择序列中的对象,用途:
1) 使用方法iterator()要求容器返回一个Iterator。第一次调用Iterator的next()方法时,它返回序列的第一个元素。注意:iterator()方法是java.lang.Iterable接口,被Collection继承。
2) 使用next()获得序列中的下一个元素。
3) 使用hasNext()检查序列中是否还有元素。
4) 使用remove()将迭代器新返回的元素删除。
通过使用迭代器遍历整个序列,就不必为容器中的元素数量操心了,因为它的hasNext()和next()方法已经帮你解决。
for(int i = 0; i < list.size(); i++) ((Cat)list.get(i)).id(); 被替换为: Iterator e = list.iterator(); while(e.hasNext()) ((Cat)e.next()).id();
相关文章推荐
- 单链表的头插法与尾插法
- UISearchBar 点击取消回到原来位置时会跳动的解决方法
- Android广告的Activity收集
- QT中qlistwidget和qtableview用法
- Leetcode38 Count and Say
- Hive做数据仓库,对Hadoop Hive 的多用户的资源分配和权限管理 (Hortonworks HDP2.2 hadoop 2.6)
- 【mark】如何改变VC中控件间的TAB切换顺序
- Hduoj1030【数学】
- [ubuntu] 在vim中查找指定字符串和在ubuntu中查找指定文件
- 【原】取消ubuntu异常关机 重启后 停止在grub的解决方法
- HDU 1087 Super Jumping! Jumping! Jumping!
- Run time setting设置详解
- java环境配置
- c++ primer 学习笔记-第三章
- GCC 4.8编译程序抛出Error: no such instruction: `某某汇编指令`
- openfire内存问题解决方法汇总
- 关于三级指针
- 单调递增最长子序列
- H. 264 算法特点
- 《C/C++/Java/Pascal 程序设计基础》习题集 解题2