Java的Collection框架细节点

集合类的由来:
对象用于封装特有数据,对象多了需要存储,如果对象的个数不确定。
就使用集合容器进行存储。

集合特点:
1,用于存储对象的容器。
2,集合的长度是可变的。
3,集合中不可以存储基本数据类型值。
4,集合都有迭代器Iterator

Collection
|--List:有序(存入和取出的顺序一致),元素都有索引(角标),元素可以重复。
|--Set:元素不能重复,无序。

List:
|--Vector:内部是数组数据结构,是同步的。增删,查询都很慢!
|--ArrayList:内部是数组数据结构,是不同步的。替代了Vector。查询的速度快。
|--LinkedList:内部是链表数据结构,是不同步的。增删元素的速度很快。

Set:元素不可以重复,是无序。
            |--HashSet: 内部数据结构是哈希表 ,是不同步的。
            如何保证该集合的元素唯一性呢?
            是通过对象的hashCode和equals方法来完成对象唯一性的。
            如果对象的hashCode值不同,那么不用判断equals方法,就直接存储到哈希表中。
            如果对象的hashCode值相同,那么要再次判断对象的equals方法是否为true。
            如果为true,视为相同元素,不存。如果为false,那么视为不同元素,就进行存储。
            记住:如果元素要存储到HashSet集合中,必须覆盖hashCode方法和equals方法。
            一般情况下,如果定义的类会产生很多对象,比如人,学生,书,通常都需要覆盖equals,hashCode方法。
            建立对象判断是否相同的依据。

            |--TreeSet:可以对Set集合中的元素进行排序。是不同步的。
            判断元素唯一性的方式:就是根据比较方法的返回结果是否是0,是0,就是相同元素,不存。
            TreeSet对元素进行排序的方式一:
            让元素自身具备比较功能,元就需要实现Comparable接口。覆盖compareTo方法。
            如果不要按照对象中具备的自然顺序进行排序。如果对象中不具备自然顺序。怎么办?
            可以使用TreeSet集合第二种排序方式二:
            让集合自身具备比较功能,定义一个类实现Comparator接口,覆盖compare方法。
            将该类对象作为参数传递给TreeSet集合的构造函数。

原文地址:http://blog.51cto.com/janephp/2146910

时间: 2024-10-02 19:01:13

Java的Collection框架细节点的相关文章

java中Collection框架的讲解

下面要开始java中相关集合框架的学习啦. Are you ready?Let's go~~ 今天要讲解的Java中的Collection框架. 1) 首先查看jdk中Collection类的源码后会发现如下内容: ... * @see AbstractCollection * @since 1.2 */ public interface Collection<E> extends Iterable<E> { // Query Operations 通过查看可以发现Collecti

【java】Collection框架

★存储对象:数组.集合对象多了用集合存,数据多了用对象存★数组和集合的不同? 数组长度是固定的,集合长度是可变的 数组中只能存储同一类型的对象,而集合中存储的只要是对象就行 ★集合框架:是不断向上抽取共性出来的  Collection框架中包含了大量集合接口以及这些接口的实现类和操作它们的算法(比如排序.迭代.查找等等),collection主要提供了List(列表).Queue(队列).Set(集合).Stack(栈)和Map(映射表,用于存放键值对)等数据结构,其中List.Queue.Se

java之Collection框架

Collection的一些框架类的关系图: 1 Collection简介 Collection的定义 public interface Collection<E> extends Iterable<E> {} 它是一个接口,是高度抽象出来的集合,它包含了集合的基本操作:添加.删除.清空.遍历(读取).是否为空.获取大小.是否保护某元素等等. Collection接口的所有子类(直接子类和间接子类)都必须实现2种构造函数:不带参数的构造函数 和 参数为Collection的构造函数.

Java中Collection和Collections的区别

1.java.util.Collection 是一个集合接口(集合类的一个顶级接口).它提供了对集合对象进行基本操作的通用接口方法.Collection接口在Java 类库中有很多具体的实现.Collection接口的意义是为各种具体的集合提供了最大化的统一操作方式,其直接继承接口有List与Set. Collection   ├List   │├LinkedList   │├ArrayList   │└Vector   │ └Stack   └Set 2.java.util.Collectio

java类库 collection与collections (转)

http://www.cnblogs.com/dashi/p/3597937.html Java中Collection和Collections的区别 1.java.util.Collection 是一个集合接口(集合类的一个顶级接口).它提供了对集合对象进行基本操作的通用接口方法.Collection接口在Java 类库中有很多具体的实现.Collection接口的意义是为各种具体的集合提供了最大化的统一操作方式,其直接继承接口有List与Set. Collection   ├List   │├

Java中Collection和Collections的区别(引用自:http://www.cnblogs.com/dashi/p/3597937.html)

1.java.util.Collection 是一个集合接口(集合类的一个顶级接口).它提供了对集合对象进行基本操作的通用接口方法.Collection接口在Java 类库中有很多具体的实现.Collection接口的意义是为各种具体的集合提供了最大化的统一操作方式,其直接继承接口有List与Set. Collection   ├List   │├LinkedList   │├ArrayList   │└Vector   │ └Stack   └Set 2.java.util.Collectio

Java编程手冊-Collection框架(上)

该文章所讲内容基本涵盖了Collection里面的全部东西,尽管基于jdk 1.5的.可是思路非常清晰 1.引言 1.1 Collection框架的介绍 尽管我们能够使用数组去存储具有同样类型的元素集合(包含基本类型和对象类型),可是数组不支持所谓的动态内存分配,一旦分配之后,它的长度就是固定的,无法改变,另外,数组是一个简单的线性结构.在我们的实际开发中,可能会须要更复杂的数据结构.比如linked list, stack, hash table, sets, 或者 trees. 在Java中

Java编程手册-Collection框架(下)

5.  Set<E>接口与实现 Set<E>接口表示一个数学的集合,它不允许元素的重复,只能包含一个null元素. Set<E>接口声明了下面抽象方法. boolean add(E o) // add the specified element if it is not already present boolean remove(Object o) // remove the specified element if it is present boolean con

java并行调度框架封装及示例

参考资料:  阿里巴巴开源项目 CobarClient  源码实现. 分享作者:闫建忠 分享时间:2014年5月7日 --------------------------------------------------------------------------------------- 并行调度封装类设计: BXexample.java package org.hdht.business.ordermanager.quartzjob; import java.util.ArrayList;