`
mabusyao
  • 浏览: 255621 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

Java Collection结构

    博客分类:
  • java
阅读更多



在介绍Java集合类之前,首先介绍一下Java集合的概念。

Java集合Collection接口

Collection 是任何对象组,元素各自独立,通常拥有相同的套用规则。Set List由它派生。

基本操作:

增加元素add(Object obj); addAll(Collection c);

删除元素 remove(Object obj); removeAll(Collection c);

求交集 retainAll(Collection c);

删除元素 remove(Object obj); removeAll(Collection c);

求交集 retainAll(Collection c);

访问/遍历集合元素的好办法是使用Iterator接口(迭代器用于取代Enumeration)

   1. Public interface Iterator{ 
   2. 
   3.     Public Boolean hasNext(}; 
   4. 
   5.      Public Object next(}; 
   6. 
   7.      Public void remove(}; 
   8. 
   9. }

一、set

无重复、无序

HashSet-基于散列表的集,加进散列表的元素要实现hashCode()方法以判断是否为同一个对象,无顺序、无重复。

LinkedHashSet-在HashSet中加入了链表数据结构,有顺序

TreeSet-可以排序,需要实现Comparable接口,并实现其compareTo()方法,以排序。

二、List

有重复、有序

ArrayList(数组表)- 有重复、有顺序。类似于Vector,都用于缩放数组维护集合。区别:

1.同步性:Vector是线程安全的,也就是说是同步的,而ArrayList是线程序不安全的,不是同步的

2.数据增长:当需要增长时,Vector默认增长为原来一培,而ArrayList却是原来的一半

LinkedList(链表)-是双向链表,适合变更很多的List。

用在FIFO,用addList()加入元素 removeFirst()删除元素

用在FILO,用addFirst()/removeLast()

ListIterator提供双向遍历next() previous(),可删除、替换、增加元素

三、Map

用于关键字/数值对,较高的存取性能。不允许重复的key,但允许重复的Value。

处理Map的三种集合

关键字集KeySet() 数值集value()   项目集enrySet()

四个具体版本

HashMap-散列表的通用映射表,无序,可在初始化时设定其大小,自动增长。

LinkedHashMap-扩展HashMap,对返回集合迭代时,维护插入顺序

WeakHashMap-基于弱引用散列表的映射表,如果不保持映射表外的关键字的引用,则内存回收程序会回收它

TreeMap-基于平衡树的映射表

四、Java集合类collections

用于同步集合,还能改变集合只读方式的类

e.g.:

   1. Map mp=new HashMap(); 
   2. 
   3. mp=Collections.synchronizedMap(mp); //生成线程安全的映射表 
   4. 
   5. mp=Collections.unmodifiableMap(mp); //生成只读映射表

五、Comparable 自然顺序的排序类 Comparator 面向树的集合排序类

六、Vector类

Vector,可以动态增加容量。对它的操作简要如下

七、Enumeration接口

八、Dictionary类

字典。关键字/数值方式存取数据,如果映射没有此关键字,取回null。

九、Hashtable类

Dictionary结构的具体实现。

1、Collection 和 Collections的区别。

Collections是个java.util下的类,它包含有各种有关java集合操作的静态方法。

Collection是个java.util下的接口,它是各种java集合结构的父接口

2、List, Set, Map是否继承自Collection接口? List,Set是 Map不是

3、ArrayList和Vector的区别。

(1).同步性:Vector是线程安全的,也就是说是同步的,而ArrayList是线程序不安全的,不是同步的

(2).数据增长:当需要增长时,Vector默认增长为原来一培,而ArrayList却是原来的一半

4、HashMap和Hashtable的区别

(1).历史原因:Hashtable是基于陈旧的Dictionary类的,HashMap是Java 1.2引进的Map接口的一个实现

(2).同步性:Hashtable是线程安全的,也就是说是同步的,而HashMap是线程序不安全的,不是同步的

(3).值:只有HashMap可以让你将空值作为一个表的条目的key或value
  • 大小: 35.7 KB
分享到:
评论

相关推荐

    java collection framework

    ### Java Collection Framework 相关知识点 #### 一、引言 在 Java 领域,《Java Collection Framework》这本书被广泛认为是一本优秀的教程,尤其适合初学者了解集合框架的前世今生。通过本书的学习,读者不仅能...

    各种类型的collection结构java 实现

    在Java编程语言中,集合(Collection)框架是用于存储和操作对象的重要部分。这个框架提供了多种数据结构,如栈(Stack)、队列(Queue)、表(List)和包(Set),来满足不同的需求。让我们深入探讨一下这些集合...

    java Collection类整理

    Java集合框架中的`Collection`接口是所有单值容器的基础接口,它定义了基本的增删查改元素的方法。`Collection`有两个主要的子接口:`List`和`Set`。`List`接口要求元素保持特定的顺序,并允许重复元素;而`Set`接口...

    java泛型集合 java集合 集合 java Collection

    Java集合框架是一个包含多种数据结构(如列表、集、队列等)的API,这些数据结构由接口(如`Collection`、`List`、`Set`和`Queue`)和实现这些接口的类(如`ArrayList`、`HashSet`和`LinkedList`)组成。`Collection...

    关于Java_Collection_API_

    ### Java Collection API 关键知识点详解 #### 一、线程安全集合类 在Java的Collection框架中,集合类被划分为两大类:线程安全集合类与非线程安全集合类。早期版本的集合类(如`Vector`和`Hashtable`)通过`...

    java collection

    Java集合框架是Java编程语言中一个非常核心的部分,它提供了数据结构和算法的实现,使得开发者可以方便地存储和管理对象。在这个学习笔记中,我们将深入探讨ArrayList、HashMap、LinkedList和HashSet这四个重要的...

    java数据结构总结

    "java数据结构总结" java数据结构是计算机科学中研究非数值计算的程序设计问题中计算机的操作对象以及它们之间的关系和操作等等的学科。下面是java数据结构的知识点总结: 一、数据结构定义 数据结构是相互之间...

    JAVA COLLECTION (APress)

    《JAVA COLLECTION》是一本专注于Java集合框架的书籍,由APress出版社出版。这本书深入浅出地探讨了Java API中的各种数据结构,是学习和理解Java集合框架的理想资源。作者通过简洁明了的语言,使得初学者也能轻松...

    Java集合Collection、List、Set、Map使用详解

    总结,Java集合框架提供了多种数据结构,以适应不同的需求。理解并熟练运用这些集合,可以帮助我们编写出更高效、更易于维护的代码。在实际开发中,选择合适的集合类型、理解和利用它们的内部实现原理,对于提升程序...

    Java软件结构 设计和使用数据结构

    在Java中,集合框架(Collection Framework)是一组接口和类,它们提供了处理对象集合的标准方法。这些接口包括List、Set、Queue和Map,而ArrayList、HashSet、LinkedList、PriorityQueue和HashMap等则是它们的常见...

    Java collection_java_控制服务器_服务器_

    在“Java collection_java_控制服务器_服务器_”这个主题中,我们将深入探讨Java集合框架以及如何利用它们来构建服务器控制程序。 首先,Java集合框架包括接口(如List、Set、Queue)和实现这些接口的具体类(如...

    Java体系结构介绍

    ### Java体系结构介绍 #### 一、Java 是什么 Java是一种高级编程语言,它具有开放性、跨平台性、安全性及面向对象等特性。Java语言的设计借鉴了C和C++等面向对象语言的经验,但在语法上更为简洁。它可以运行在多种...

    JAVA中常用的数据结构

    "JAVA中常用的数据结构" ...JAVA中常用的数据结构有很多,如Collection、List、Map、Set等,每种数据结构都有其特点和使用场景, JAVA开发者需要根据实际情况选择合适的数据结构来实现自己的应用程序。

    Java数据结构

    Java中的集合框架是指为表示和操作集合而规定的一套标准体系结构,它包括对外的接口、接口的实现和对集合运算的算法。 Java集合框架对于编程具有重要意义,它简化了程序设计的难度,并提高了程序的运行效率和质量。...

    java Collection&Map

    Java集合框架是Java编程语言中一个非常重要的组成部分,它提供了数据结构和算法的抽象,使得开发者可以方便地存储和管理对象。在这个框架中,Collection和Map接口及其实现类扮演着核心角色。 1. **Collection接口**...

    JAVA_Collection框架

    ### JAVA Collection框架详解 #### 一、概述 Java Collection框架 是 Java 核心库中...通过上述分析,我们可以看出 Java Collection 框架为我们提供了丰富的工具来处理不同类型的数据结构需求,大大提高了开发效率。

    Java数据结构--13.Java8数据结构TreeSet.pdf

    《Java8数据结构——TreeSet详解》 在Java集合框架中,TreeSet是一个重要的数据结构,它是Set接口的实现类之一,与HashSet和LinkedHashSet不同,TreeSet具有排序功能,这是因为其不仅继承自AbstractSet,还实现了...

    数据结构和Java集合框架

    数据结构和Java集合框架是Java编程中至关重要的概念,它们是高效编程和算法设计的基础。在Java中,数据结构指的是组织、存储和管理数据的方式,而集合框架则是一组接口和类,为处理各种数据结构提供了统一的API。 ...

Global site tag (gtag.js) - Google Analytics