自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

介紹Java集合類(Collections)

開發(fā) 后端
本文介紹了java.util下的接口Collection和集合類Collections的相關(guān)知識(shí),供大家參考。

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

Java集合Collection接口

Collection 是任何對(duì)象組,元素各自獨(dú)立,通常擁有相同的套用規(guī)則。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.  

一、set

無重復(fù)、無序

HashSet-基于散列表的集,加進(jìn)散列表的元素要實(shí)現(xiàn)hashCode()方法以判斷是否為同一個(gè)對(duì)象,無順序、無重復(fù)。

LinkedHashSet-在HashSet中加入了鏈表數(shù)據(jù)結(jié)構(gòu),有順序

TreeSet-可以排序,需要實(shí)現(xiàn)Comparable接口,并實(shí)現(xiàn)其compareTo()方法,以排序。

二、List

有重復(fù)、有序

ArrayList(數(shù)組表)- 有重復(fù)、有順序。類似于Vector,都用于縮放數(shù)組維護(hù)集合。區(qū)別:

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

2.數(shù)據(jù)增長(zhǎng):當(dāng)需要增長(zhǎng)時(shí),Vector默認(rèn)增長(zhǎng)為原來一培,而ArrayList卻是原來的一半

LinkedList(鏈表)-是雙向鏈表,適合變更很多的List。

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

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

ListIterator提供雙向遍歷next() previous(),可刪除、替換、增加元素

三、Map

用于關(guān)鍵字/數(shù)值對(duì),較高的存取性能。不允許重復(fù)的key,但允許重復(fù)的Value。

處理Map的三種集合

關(guān)鍵字集KeySet() 數(shù)值集value()   項(xiàng)目集enrySet()

四個(gè)具體版本

HashMap-散列表的通用映射表,無序,可在初始化時(shí)設(shè)定其大小,自動(dòng)增長(zhǎng)。

LinkedHashMap-擴(kuò)展HashMap,對(duì)返回集合迭代時(shí),維護(hù)插入順序

WeakHashMap-基于弱引用散列表的映射表,如果不保持映射表外的關(guān)鍵字的引用,則內(nèi)存回收程序會(huì)回收它

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,可以動(dòng)態(tài)增加容量。對(duì)它的操作簡(jiǎn)要如下

七、Enumeration接口 

八、Dictionary類

字典。關(guān)鍵字/數(shù)值方式存取數(shù)據(jù),如果映射沒有此關(guān)鍵字,取回null。

九、Hashtable類

Dictionary結(jié)構(gòu)的具體實(shí)現(xiàn)。 

1、Collection 和 Collections的區(qū)別。

Collections是個(gè)java.util下的類,它包含有各種有關(guān)java集合操作的靜態(tài)方法。 

Collection是個(gè)java.util下的接口,它是各種java集合結(jié)構(gòu)的父接口

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

3、ArrayList和Vector的區(qū)別。

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

(2).數(shù)據(jù)增長(zhǎng):當(dāng)需要增長(zhǎng)時(shí),Vector默認(rèn)增長(zhǎng)為原來一培,而ArrayList卻是原來的一半

4、HashMap和Hashtable的區(qū)別

(1).歷史原因:Hashtable是基于陳舊的Dictionary類的,HashMap是Java 1.2引進(jìn)的Map接口的一個(gè)實(shí)現(xiàn)

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

(3).值:只有HashMap可以讓你將空值作為一個(gè)表的條目的key或value

Java集合類的相關(guān)內(nèi)容就介紹到這里。

【編輯推薦】

  1. 多核時(shí)代考驗(yàn)Java代碼編寫習(xí)慣
  2. JSR通過JavaEE 6依賴注入標(biāo)準(zhǔn) 各方觀點(diǎn)不一
  3. Sun發(fā)布JDK 7早期預(yù)覽版 JVM性能大幅提升
  4. 來自一年前的預(yù)測(cè):Java平臺(tái)與死亡相去甚遠(yuǎn)
  5. Java新型垃圾回收器G1深入探索
責(zé)任編輯:book05 來源: 新浪博客
相關(guān)推薦

2009-05-08 09:46:37

微軟C#集合對(duì)象

2011-07-11 11:02:12

JAVA集合框架

2024-11-08 16:54:38

2025-02-10 07:40:00

Java集合工具類編程

2021-08-16 09:35:34

Collections Java開發(fā)

2012-03-19 09:57:09

JavaArrayList

2012-05-02 10:47:51

JavaJava集合框架

2010-03-16 14:58:15

Java類加載器

2009-10-20 09:39:04

VB.NET Butt

2009-12-21 15:58:19

ADO.NET集合

2009-10-27 14:50:25

VB.NET控件數(shù)組

2019-05-07 11:02:55

Java開發(fā)代碼

2024-02-23 10:10:00

List接口Java

2009-09-15 13:20:34

LINQ DataCo

2009-08-12 09:41:28

C# Director

2009-09-03 15:57:11

C# SystemMe

2010-02-24 17:47:05

WCF集合類型

2011-06-22 09:58:04

QT 集合類

2011-07-12 10:43:20

JAVA類加載

2009-08-06 14:53:41

C# User類
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)