线性表,链表,哈希表是常用的数据结构,在进行Java开发时,JDK已经为我们提供了一系列相应的类来实现基本的数据结构。这些类均在java.util包中。本文试图通过简单的描述,向读者阐述各个类的作用以及如何正确使用这些类。
Collection
├List
│├LinkedList
│├ArrayList
│└Vector
│ └Stack
└Set
Map
├Hashtable
├HashMap
└WeakHashMap
Collection接口
Collection是最基本的集合接口,一个Collection代表一组Object,即Collection的元素(Elements)。一些Collection允许相同的元素而另一些不行。一些能排序而另一些不行。JavaSDK不提供直接继承自Collection的类,JavaSDK提供的类都是继承自Collection的“子接口”如List和Set。
所有实现Collection接口的类都必须提供两个标准的构造函数:无参数的构造函数用于创建一个空的Collection,有一个Collection参数的构造函数用于创建一个新的Collection,这个新的Collection与传入的Collection有相同的元素。后一个构造函数允许用户复制一个Collection。
如何遍历Collection中的每一个元素?不论Collection的实际类型如何,它都支持一个iterator()的方法,该方法返回一个迭代子,使用该迭代子即可逐一访问Collection中每一个元素。典型的用法如下:
Iteratorit=collection.iterator();//获得一个迭代子
while(it.hasNext()){
Objectobj=it.next();//得到下一个元素
}
由Collection接口派生的两个接口是List和Set。
List接口
List是有序的Collection,使用此接口能够精确的控制每个元素插入的位置。用户能够使用索引(元素在List中的位置,类似于数组下标)来访问List中的元素,这类似于Java的数组。
和下面要提到的Set不同,List允许有相同的元素。
除了具有Collection接口必备的iterator()方法外,List还提供一个listIterator()方法,返回一个ListIterator接口,和标准的Iterator接口相比,ListIterator多了一些add()之类的方法,允许添加,删除,设定元素,还能向前或向后遍历。
实现List接口的常用类有LinkedList,ArrayList,Vector和Stack。
LinkedList类
LinkedList实现了List接口,允许null元素。此外LinkedList提供额外的get,remove,insert方法在LinkedList的首部或尾部。这些操作使LinkedList可被用作堆栈(stack),队列(queue)或双向队列(deque)。
注意LinkedList没有同步方法。如果多个线程同时访问一个List,则必须自己实现访问同步。一种解决方法是在创建List时构造一个同步的List:
Listlist=Collections.synchronizedList(newLinkedList(...));
ArrayList类
ArrayList实现了可变大小的数组。它允许所有元素,包括null。ArrayList没有同步。
size,isEmpty,get,set方法运行时间为常数。但是add方法开销为分摊的常数,添加n个元素需要O(n)的时间。其他的方法运行时间为线性。
每个ArrayList实例都有一个容量(Capacity),即用于存储元素的数组的大小。这个容量可随着不断添加新元素而自动增加,但是增长算法并没有定义。当需要插入大量元素时,在插入前可以调用ensureCapacity方法来增加ArrayList的容量以提高插入效率。
和LinkedList一样,ArrayList也是非同步的(unsynchronized)。
Vector类
Vector非常类似ArrayList,但是Vector是同步的。由Vector创建的Iterator,虽然和ArrayList创建的Iterator是同一接口,但是,因为Vector是同步的,当一个Iterator被创建而且正在被使用,另一个线程改变了Vector的状态(例如,添加或删除了一些元素),这时调用Iterator的方法时将抛出ConcurrentModificationException,因此必须捕获该异常。
Stack类
Stack继承自Vector,实现一个后进先出的堆栈。Stack提供5个额外的方法使得Vector得以被当作堆栈使用。基本的push和pop方法,还有peek方法得到栈顶的元素,empty方法测试堆栈是否为空,search方法检测一个元素在堆栈中的位置。Stack刚创建后是空栈。
Set接口
Set是一种不包含重复的元素的Collection,即任意的两个元素e1和e2都有e1.equals(e2)=false,Set最多有一个null元素。
很明显,Set的构造函数有一个约束条件,传入的Collection参数不能包含重复的元素。
请注意:必须小心操作可变对象(MutableObject)。如果一个Set中的可变元素改变了自身状态导致Object.equals(Object)=true将导致一些问题。
Map接口
请注意,Map没有继承Collection接口,Map提供key到value的映射。一个</sp
分享到:
相关推荐
本篇文章将深入探讨两个重要的数据结构实现类:Collection和Map,以及它们在Java中的应用。 首先,Collection是Java集合框架的顶层接口,它是所有单值容器的父接口。Collection接口定义了对一组对象进行操作的基本...
"JAVA中常用的数据结构" ...JAVA中常用的数据结构有很多,如Collection、List、Map、Set等,每种数据结构都有其特点和使用场景, JAVA开发者需要根据实际情况选择合适的数据结构来实现自己的应用程序。
`Collection`和`Map`是Java集合框架的核心组成部分,它们提供了丰富的数据结构实现,方便开发者高效地管理对象。 `Collection`接口是最基础的集合接口,它定义了一个包含零个或多个对象的集合。`Collection`接口的...
除了上述数据结构,Java还提供了集合框架(Collection Framework),包括List、Set、Map接口,以及对应的实现类如ArrayList、LinkedList、HashSet、TreeSet、HashMap等,这些类和接口大大简化了数据结构的使用。...
### JAVA常用的数据结构和算法 ...以上就是Java中常用的数据结构和部分相关算法的基本介绍。这些数据结构和算法在Java程序开发中起着至关重要的作用,了解它们的工作原理可以帮助开发者编写出更加高效和健壮的代码。
List、ArrayList、Vector及map、HashTable是Java中常用的容器类,它们都继承自Collection接口,并提供了不同的实现方式和特点。在实际开发中,选择合适的容器类是非常重要的。 Collection接口是Java中最基本的集合...
Java中的容器框架是数据结构和算法在Java中的体现,它包括Collection和Map两大接口,以及具体实现如ArrayList、LinkedList、HashMap、TreeMap等。面试中常考的问题有Collection和Collections的区别、List、Set、Map...
以上是Java中常用的数据结构,理解并熟练运用它们能极大地提升代码的效率和质量。在实际编程中,选择合适的数据结构取决于具体需求,如数据的访问模式、是否允许重复元素以及对操作性能的要求。
2.4 Java类库组织结构和文档27 2.5 Java虚拟机简介28 2.6 Java技术两种核心运行机制29 2.7 上机练习30 第3章 3.1 变量32 3.1.1 什么是变量32 3.1.2 为什么需要变量32 3.1.3 变量的声明和赋值33 3.1.4 变量应用实例33...
- `Map`接口的实现类:HashMap、TreeMap、Hashtable、ConcurrentHashMap和Properties等。 - `Collection`接口的子接口:Set接口和List接口。 - Set接口的实现类:HashSet、TreeSet、LinkedHashSet等。 - List...
对于数组和集合框架的理解也是必不可少的,例如List、Set、Queue和Map接口,以及它们的实现类ArrayList、LinkedList、HashSet、HashMap等。 其次,深入理解Java内存管理至关重要,特别是垃圾回收(Garbage ...
还要了解Collection和Map接口,以及泛型的使用。 3. **异常处理**:理解Checked和Unchecked异常的区别,掌握如何正确使用try-catch-finally结构,以及如何自定义异常。 4. **多线程**:包括线程的创建方式(Thread...
集合框架是Java中用于存储和操作一组对象的数据结构的集合,主要包括`Collection`和`Map`两大接口。`Collection`接口表示单个对象的集合,而`Map`接口则表示键值对的集合。集合框架提供了多种实现,如`ArrayList`、`...
了解这两种数据结构的特性和适用场景,对于选择合适的数据结构进行高效的数据存储和检索非常重要。 通过以上知识点的总结,可以看出Java面试题涵盖了从基础语法到高级框架的各个方面,掌握这些知识对于成为一名合格...
Java中常用的数据结构包括数组、链表、栈、队列等。掌握这些基本数据结构的特性和使用场景对于编写高效算法非常重要。 #### (22) 单例模式 单例模式是一种常用的创建型设计模式,用于确保一个类只有一个实例,并...
13. **算法与数据结构**:虽然不是Java语言本身的特性,但面试中常考察排序算法(冒泡、选择、插入、快速、归并等)、查找算法(二分查找、哈希查找等)以及链表、树、图等数据结构的理解和实现。 14. **Java 8及...
`List`的实现类有`ArrayList`、`LinkedList`和`Vector`,`Set`有`HashSet`、`TreeSet`和`LinkedHashSet`,而`Queue`则涉及`BlockingQueue`等阻塞队列。`Map`接口的主要实现包括`HashMap`、`LinkedHashMap`、`...
List、Set、Map接口的实现类如ArrayList、LinkedList、HashSet、HashMap等的特性和使用场景需要熟记于心。面试中可能会让你比较它们的性能差异,并解释原因。 并发编程是Java技术栈的重要部分。线程的创建与管理、...
- Java中常用的哈希算法有`hashCode()`方法,用于确定对象的哈希值。 #### 十、对象与哈希算法 - **Object类**中的`hashCode()`方法用于生成对象的哈希值。 - `equals()`方法用于比较两个对象是否相等。 - 正确地...