[零基础学JAVA]Java SE应用部分-35.JAVA类集之四

1、类集结构

(1)类集的产生目的

类集简单来讲就是一个动态的对象数组,此对象数组可以改变大小,可以任意的实现对象的增加、删除、输出。所有的类集存放java.util包中。

(2)类集的划分

1、存放单值:Collection

2、存放一对值:Map

3、输出:Iterator

(3)类集的具体概念

<1>Collection(只能存放一个值)

|- 主要功能:用于输出使用

|- 子接口:List(允许有重复的元素,而且加入的顺序就是输出的顺序)

|- 子类:ArrayList,是在Java 2之后推出的,是新的类,是使用异步处理方式,其性能较高

|- 子类:Vector,是在JDK 1.0的时候就推出,因为是旧的类,有很多List所没有的功能,是使用同步处理方式,其线程安全性较高,会比较慢。使用Vector除了可以使用Iterator输出之外,也可以使用Enumeration进行输出。两者是通用的。Vector子类允许直接使用addElement(Object obj),也是可以向集合中加入元素的。

|- 自己新增的方法:

|- 取每一个对象:public Object get(int ind) ;

|- 子类:Stack(栈)

|- 子接口:Set(不允许有重复元素,重复元素会替换)?如何可以区分重复元素呢?

|- 子类:HashSet:是无序列存放

|- 子类:TreeSet:有序存放,是通过Comparable接口完成的

|- 常用方法:

|- 增加一个对象:public boolean add(Object obj)

|- 取得类集的长度:public int size() ;

|- 判断集合中的内容是否为空:public boolean isEmpty()

|- 删除一个对象:public boolean remove(Object obj) :就必须牵扯到对象的比较状态。

|- 实例化Iterator对象:public Iterator iterator() ;

<2>JDK 1.5提供了一个方便的输出操作:for…each语句。

<3>Iterator接口输出是最常见的

|- 常用方法

|- public boolean hasNext():判断是否有下一个元素

|- public Object next():取出下一个元素

|- 子接口:ListIterator,可以进行双向输出,只对于List接口有用

|- 常用方法:具备了Iterator接口中的全部内容

|- public boolean hasPrevious()

|- public Object previous()

<4>Enumeration(在1.5之后也加入、泛型支持哈~)

|- 常用方法:

|- 判断是否有下一个元素:public boolean hasMoreElements()

|- 取出元素:public Object element()

5、 Map(存放一对值)

|- 功能:与Collection的功能不一样,Map的主要功能是用于查找使用的。

|- 注意点:

|- 使用Map操作时,不能直接使用Iterator进行输出。

|- 而且里面不能有重复key。

|- 如果非要使用Iterator进行输出,则必须按以下的步骤进行操作:

|- Map --> Set --> Iterator --> Map.Entry --> key与value的分离

|- 常用子类:

|- HashMap:无序存放,是新的类,是JDK 1.2时推出的,是异步处理,性能较高

|- Hashtable:是旧的类,是JDK 1.0时推出的,是线程安全的,性能较低

|- Properties(重点):属性文件操作类

|- TreeMap:有序存放

|- 常用方法:

|- 向集合中保存数据:public Object put(Object key,Object value):返回的是value

|- 从集合中查找数据:public Object get(Object key):根据key查找。

|- 将Map数据变为Set实例:Set<Map.Entry<K,V>> entrySet()

|- 将全部的key变为set实例:Set<K> keySet()

|- 将全部的vlaue变为Collection接口实例:Collection<V> values()

|- Map.Entry:保存key与value

|- public Object getKey()

|- public Object getValue()

|- 存放key的注意点:

################Michael分割线####################

2、代码讲解

(11)HashMap

Map的基本应用
[零基础学JAVA]Java SE应用部分-35.JAVA类集之四

如果查到了,则返回具体的值,如果没有查到,则返回null

[零基础学JAVA]Java SE应用部分-35.JAVA类集之四
使用Iterator输出Map接口中的内容

[零基础学JAVA]Java SE应用部分-35.JAVA类集之四
HashSet:是无序列存放滴~~~

[零基础学JAVA]Java SE应用部分-35.JAVA类集之四
将全部的key进行输出
[零基础学JAVA]Java SE应用部分-35.JAVA类集之四

[零基础学JAVA]Java SE应用部分-35.JAVA类集之四
输出全部的值
[零基础学JAVA]Java SE应用部分-35.JAVA类集之四

[零基础学JAVA]Java SE应用部分-35.JAVA类集之四
(12)Hashtable
[零基础学JAVA]Java SE应用部分-35.JAVA类集之四

[零基础学JAVA]Java SE应用部分-35.JAVA类集之四
(13)TreeMap

按key进行排序,本操作中依然使用了Comparable接口。
[零基础学JAVA]Java SE应用部分-35.JAVA类集之四

TreeSet:有序存放,是通过Comparable接口完成的

[零基础学JAVA]Java SE应用部分-35.JAVA类集之四
(14)Stack

入栈:public Object push(Object obj)

出栈:public Object pop()

注意点:如果此时栈中已经没有内容了,则会出现异常。
[零基础学JAVA]Java SE应用部分-35.JAVA类集之四

[零基础学JAVA]Java SE应用部分-35.JAVA类集之四
(15)Properties(重点)

· 属性操作类,所有的key 与value 都按属性设置,都是字符串。而且此属性文件可以直接保存在文件中,或从文件中读取出来。

设置属性:public Object setProperties(String key,String value)

取得属性:

|- public String getProperty(String key) :根据key读取属性,返回值

|- public String getProperty(String key,String def) :如果没有读到值,则返回def指定的内容。

保存在文件中:

|- 保存成普通文件:public void store(OutputStream out,String comments) throws IOException

|- 保存成XMl文件:public void storeToXML(OutputStream out,String comments) throws IOException

从文件中读取属性:

|- 从普通文件中读取:public void load(InputStream input) throws IOException

|- 从XML文件中读取:public void loadFromXML(InputStream input) throws IOException
[零基础学JAVA]Java SE应用部分-35.JAVA类集之四

[零基础学JAVA]Java SE应用部分-35.JAVA类集之四
将内容保存成普通文件:
[零基础学JAVA]Java SE应用部分-35.JAVA类集之四

[零基础学JAVA]Java SE应用部分-35.JAVA类集之四
将内容保存为XML文件:
[零基础学JAVA]Java SE应用部分-35.JAVA类集之四

[零基础学JAVA]Java SE应用部分-35.JAVA类集之四
从XML文件中把属性读取出来
[零基础学JAVA]Java SE应用部分-35.JAVA类集之四

[零基础学JAVA]Java SE应用部分-35.JAVA类集之四
(16)Map重要补充
[零基础学JAVA]Java SE应用部分-35.JAVA类集之四

[零基础学JAVA]Java SE应用部分-35.JAVA类集之四
以上的程序可以通过key找到value。

现在把代码反过来
[零基础学JAVA]Java SE应用部分-35.JAVA类集之四

[零基础学JAVA]Java SE应用部分-35.JAVA类集之四
代码反过来之后,发现没有得到真正想要的内容,而是返回了null。

[零基础学JAVA]Java SE应用部分-35.JAVA类集之四
[零基础学JAVA]Java SE应用部分-35.JAVA类集之四
此时如果要通过匿名对象来当作key,找到属性的话,就必须牵扯到Object中的几个方法:

· 对象比较:

· 通过hashCode;
[零基础学JAVA]Java SE应用部分-35.JAVA类集之四

[零基础学JAVA]Java SE应用部分-35.JAVA类集之四
Java中是通过equals和hashCode方法去确认对象唯一性,可以进行比较。

但是以上的程序需要一点更改,因为不能让所有对象的hashCode方法的返回值都是一样的,所以可以经过一些自己简单的运算。
[零基础学JAVA]Java SE应用部分-35.JAVA类集之四

[零基础学JAVA]Java SE应用部分-35.JAVA类集之四
一个完整的类最好覆写Object类中的三个方法:

· hashCode

· equals

· toString

(17)额外补充(对象克隆)

就是把对象的内容重新复制一份,复制出一个新的对象

protected Object clone() throws CloneNotSupportedException

克隆方法是一个受保护的方法。所以在其需要对象被克隆的子类中必须扩大权限,否则外部无法看见。

对象所在的类必须实现Cloneable接口

Java程序中常用的有两大标识接口:

· 可序列化:Serializable

· 可克隆:Cloneable
[零基础学JAVA]Java SE应用部分-35.JAVA类集之四

[零基础学JAVA]Java SE应用部分-35.JAVA类集之四
总结

就是向里面不断加入元素,可以动态的扩充,而且可以有存放单值的,也可以有存放一对值的。

而且在集合中对于排序,使用的是Comparable接口。

实例的模型很重要 —— Hibernate、EJB 3.0

欢迎工作一到五年的Java工程师朋友们加入Java架构师:697558955

群内提供免费的Java架构学习资料(里面有高可用、高并发、高性能及分布式、Jvm性能调优、Spring源码,MyBatis,Netty,Redis,Kafka,Mysql,Zookeeper,Tomcat,Docker,Dubbo,Nginx等多个知识点的架构资料)合理利用自己每一分每一秒的时间来学习提升自己,不要再用"没有时间“来掩饰自己思想上的懒惰!趁年轻,使劲拼,给未来的自己一个交代!

猜你喜欢

转载自blog.51cto.com/14233733/2373166
今日推荐