# JAVA之旅(十九)——ListIterator列表迭代器,List的三個子類對象,Vector的枚舉,LinkedList,ArrayList和LinkedList的小練習
* * *
> 關于數據結構,所講的知識太多了,我們只能慢慢的來分析了
## 一.ListIterator列表迭代器
> ListIterator列表迭代器是個什么鬼?我們通過一個小例子來認識他
~~~
package com.lgl.hellojava;
import java.util.ArrayList;
import java.util.Iterator;
import javax.print.attribute.standard.MediaSize.Other;
//公共的 類 類名
public class HelloJJAVA {
public static void main(String[] args) {
listiterator();
}
/**
* 演示列表迭代器
*/
public static void listiterator() {
/**
* 需求:對集合中的元素取出,在取的過程中進行操作
*/
ArrayList al = new ArrayList<>();
al.add("hello 01");
al.add("hello 02");
al.add("hello 03");
al.add("hello 04");
// 在迭代過程中,準備添加或者刪除元素
Iterator it = al.iterator();
while (it.hasNext()) {
Object obj = it.next();
if (obj.equals("hello 02")) {
// 將這個元素刪除
al.add("hello 05");
sop(obj);
}
}
}
/**
* 輸出
*/
public static void sop(Object obj) {
System.out.println(obj);
}
}
~~~
> 我們用老方法的思路去做我們的需求,是這樣的,你運行后悔發現

> 他打印了02缺報異常了,我們于是要去查看API

> 他不清楚怎么去操作,這也是這個迭代器的缺陷
* list集合特有的迭代器叫做ListIterator,是Iterator的子接口,在迭代時,不可以通過集合對象的方法操作集合中的元素,因為會發現并發修改異常,所以,在迭代器時,只能用迭代器的方式操作元素,可是Iterator方法有限,如果想要其他的操作如添加,修改等,就需要使用其子接口:ListIterator,該接口只能通過list集合的ListIterator方法獲取
> 所以我們可以這樣去修改
~~~
package com.lgl.hellojava;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.ListIterator;
//公共的 類 類名
public class HelloJJAVA {
public static void main(String[] args) {
listiterator();
}
/**
* 演示列表迭代器
*/
public static void listiterator() {
/**
* 需求:對集合中的元素取出,在取的過程中進行操作
*/
ArrayList al = new ArrayList<>();
al.add("hello 01");
al.add("hello 02");
al.add("hello 03");
al.add("hello 04");
sop(al);
ListIterator li = al.listIterator();
while (li.hasNext()) {
Object object = li.next();
if (object.equals("hello 03")) {
li.add("lgl");
}
}
sop(al);
// 在迭代過程中,準備添加或者刪除元素
// Iterator it = al.iterator();
// while (it.hasNext()) {
// Object obj = it.next();
//
// if (obj.equals("hello 02")) {
// // 將這個元素刪除
// // al.add("hello 05");
// it.remove();
// sop(obj);
// }
// sop(al);
// }
}
/**
* 輸出
*/
public static void sop(Object obj) {
System.out.println(obj);
}
}
~~~
> 不僅可以增加,還可以修改,刪除等操作

## 二.List的三個子類對象
> List有三個子類對象
* ArrayList
* LinkedList
* Vector
> 為什么會有三個?因為底層的數據結構不一樣,那具體是怎么樣的呢?
* ArrayList?
* 底層的數據結構使用的是數組結構,特點:查詢速度很快,但是增刪稍慢,元素不多的話,你體會不到的。線程不同步。
* LinkedList?
* 底層使用的鏈表數據結構,特點:增刪的速度很快,查詢的速度慢。
* Vector?
* 底層是數組數據結構,線程同步。做什么都慢,被ArrayList替代了
> ArrayList和Vector都是數組結構,他們有什么具體的區別呢?
* ArrayList構造一個初始容量為10的空列表,當長度超過10之后增加50%,而后者,長度也為10,超過的話,是100%延長至20,比較浪費空間
## 三.Vector的枚舉
> 上面說了這么多,雖然Vector不用,但是我們還是要熟悉一下,面試的時候也是會問到的,所以我們寫個小例子
~~~
package com.lgl.hellojava;
import java.util.Enumeration;
import java.util.Vector;
//公共的 類 類名
public class HelloJJAVA {
public static void main(String[] args) {
Vector v = new Vector();
v.add("hello 01");
v.add("hello 02");
v.add("hello 03");
v.add("hello 04");
// 返回枚舉
Enumeration elements = v.elements();
while (elements.hasMoreElements()) {
sop(elements.nextElement());
}
}
/**
* 輸出
*/
public static void sop(Object obj) {
System.out.println(obj);
}
}
~~~
> 這樣就輸出了?
> 枚舉就是Vector特有的取出方式,我們發現枚舉和迭代器很像,其實枚舉和迭代時一樣的,因為枚舉的名稱以及方法的名稱都過長,所以被迭代器所取代了。枚舉就郁郁而終了
## 四.LinkedList
> 我們繼續來說list的子類對象LinkedList,事實上區別都不是很大,所以我們只說一些特有的特點
>
> LinkedList特有方法:
* addFirst()
* addLast();
* getFirst();
* getLast();
* removeFirst();
* removeLast();
> 我們來看
~~~
package com.lgl.hellojava;
import java.util.LinkedList;
//公共的 類 類名
public class HelloJJAVA {
public static void main(String[] args) {
LinkedList list = new LinkedList<>();
list.addFirst("hello 0");
list.addFirst("hello 1");
list.addFirst("hello 2");
list.addFirst("hello 3");
sop(list);
}
/**
* 輸出
*/
public static void sop(Object obj) {
System.out.println(obj);
}
}
~~~
> 輸出的結果

> 我們一直添加頭部,就是倒序了,這個邏輯應該都知道吧!要是addLast(),那就是順序了,我們要想知道他們的頭部和尾部的數值,也就直接get就是了
~~~
sop(list.getFirst());
sop(list.getLast());
~~~
> 獲取元素,但是元素被刪除,如果集合中沒有元素,會出異常,在JDK1.6版本后出現了替代方法
* offerFirst();
* offerLast();
* peekFirst();
* peekLast();
* pollFist();
* pollLast();?
> 之類的
## 五.小練習
> 我們寫個小練習吧,我們先看LinkedList
~~~
package com.lgl.hellojava;
import java.util.LinkedList;
//公共的 類 類名
public class HelloJJAVA {
public static void main(String[] args) {
/**
* 使用LinkedList模擬一個堆棧或者隊列數據模式 堆棧:現進后出 隊列:先進先出
*/
DuiLie dl = new DuiLie();
dl.MyAdd("hello 01");
dl.MyAdd("hello 02");
dl.MyAdd("hello 03");
dl.MyAdd("hello 04");
while (!dl.isNull()) {
sop(dl.myGet());
}
}
/**
* 輸出
*/
public static void sop(Object obj) {
System.out.println(obj);
}
}
/**
* 隊列
*
* @author LGL
*
*/
class DuiLie {
private LinkedList link;
public DuiLie() {
link = new LinkedList<>();
}
public void MyAdd(Object obj) {
link.addFirst(obj);
}
public Object myGet() {
return link.removeLast();
}
public boolean isNull() {
return link.isEmpty();
}
}
~~~
> 自己寫的一個鏈表,去使用它,這樣輸出的結果就是

> OK,那我們繼續,寫一個ArrayList的小例子
~~~
package com.lgl.hellojava;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.LinkedList;
//公共的 類 類名
public class HelloJJAVA {
public static void main(String[] args) {
/**
* 去除ArrayList的重復元素
*/
ArrayList list = new ArrayList<>();
list.add("Hello 01");
list.add("Hello 02");
list.add("Hello 03");
list.add("Hello 02");
list.add("Hello 05");
sop(list);
list = Method(list);
sop(list);
}
public static ArrayList Method(ArrayList list){
//臨時容器
ArrayList newList = new ArrayList<>();
Iterator iterator = list.iterator();
while (iterator.hasNext()) {
Object object = (Object) iterator.next();
if(!newList.contains(object)){
newList.add(object);
}
}
return newList;
}
/**
* 輸出
*/
public static void sop(Object obj) {
System.out.println(obj);
}
}
~~~
> 輸出的結果

> 好的,我們本篇幅到這里,就寫完了,但是我們的數據結構只是講了一些皮毛而已,我們接下來的幾天,將會一一為大家講解
## 我的群:555974449
版權聲明:本文為博主原創文章,博客地址:http://blog.csdn.net/qq_26787115,未經博主允許不得轉載。
- 0-發現
- AndroidInterview-Q-A
- Android能讓你少走彎路的干貨整理
- LearningNotes
- temp
- temp11
- 部分地址
- 0-待辦任務
- 待補充列表
- 0-未分類
- AndroidView事件分發與滑動沖突處理
- Spannable
- 事件分發機制詳解
- 1-Java
- 1-Java-01基礎
- 未歸檔
- 你應該知道的JDK知識
- 集合框架
- 1-Java-04合集
- Java之旅0
- Java之旅
- JAVA之旅01
- JAVA之旅02
- JAVA之旅03
- JAVA之旅04
- JAVA之旅05
- JAVA之旅06
- JAVA之旅07
- JAVA之旅08
- JAVA之旅09
- java之旅1
- JAVA之旅10
- JAVA之旅11
- JAVA之旅12
- JAVA之旅13
- JAVA之旅14
- JAVA之旅15
- JAVA之旅16
- JAVA之旅17
- JAVA之旅18
- JAVA之旅19
- java之旅2
- JAVA之旅20
- JAVA之旅21
- JAVA之旅22
- JAVA之旅23
- JAVA之旅24
- JAVA之旅25
- JAVA之旅26
- JAVA之旅27
- JAVA之旅28
- JAVA之旅29
- java之旅3
- JAVA之旅30
- JAVA之旅31
- JAVA之旅32
- JAVA之旅33
- JAVA之旅34
- JAVA之旅35
- 1-Java-05辨析
- HashMapArrayMap
- Java8新特性
- Java8接口默認方法
- 圖解HashMap(1)
- 圖解HashMap(2)
- 2-Android
- 2-Android-1-基礎
- View繪制流程
- 事件分發
- AndroidView的事件分發機制和滑動沖突解決
- 自定義View基礎
- 1-安卓自定義View基礎-坐標系
- 2-安卓自定義View基礎-角度弧度
- 3-安卓自定義View基礎-顏色
- 自定義View進階
- 1-安卓自定義View進階-分類和流程
- 10-安卓自定義View進階-Matrix詳解
- 11-安卓自定義View進階-MatrixCamera
- 12-安卓自定義View進階-事件分發機制原理
- 13-安卓自定義View進階-事件分發機制詳解
- 14-安卓自定義View進階-MotionEvent詳解
- 15-安卓自定義View進階-特殊形狀控件事件處理方案
- 16-安卓自定義View進階-多點觸控詳解
- 17-安卓自定義View進階-手勢檢測GestureDetector
- 2-安卓自定義View進階-繪制基本圖形
- 3-安卓自定義View進階-畫布操作
- 4-安卓自定義View進階-圖片文字
- 5-安卓自定義View進階-Path基本操作
- 6-安卓自定義View進階-貝塞爾曲線
- 7-安卓自定義View進階-Path完結篇偽
- 8-安卓自定義View進階-Path玩出花樣PathMeasure
- 9-安卓自定義View進階-Matrix原理
- 通用類介紹
- Application
- 2-Android-2-使用
- 2-Android-02控件
- ViewGroup
- ConstraintLayout
- CoordinatorLayout
- 2-Android-03三方使用
- Dagger2
- Dagger2圖文完全教程
- Dagger2最清晰的使用教程
- Dagger2讓你愛不釋手-終結篇
- Dagger2讓你愛不釋手-重點概念講解、融合篇
- dagger2讓你愛不釋手:基礎依賴注入框架篇
- 閱讀筆記
- Glide
- Google推薦的圖片加載庫Glide:最新版使用指南(含新特性)
- rxjava
- 這可能是最好的RxJava2.x入門教程完結版
- 這可能是最好的RxJava2.x入門教程(一)
- 這可能是最好的RxJava2.x入門教程(三)
- 這可能是最好的RxJava2.x入門教程(二)
- 這可能是最好的RxJava2.x入門教程(五)
- 這可能是最好的RxJava2.x入門教程(四)
- 2-Android-3-優化
- 優化概況
- 各種優化
- Android端秒開優化
- apk大小優化
- 內存分析
- 混淆
- 2-Android-4-工具
- adb命令
- 一鍵分析Android的BugReport
- 版本控制
- git
- git章節簡述
- 2-Android-5-源碼
- HandlerThread 源碼分析
- IntentService的使用和源碼分析
- 2-Android-9-辨析
- LRU算法
- 什么是Bitmap
- 常見圖片壓縮方式
- 3-Kotlin
- Kotlin使用筆記1-草稿
- Kotlin使用筆記2
- kotlin特性草稿
- Kotlin草稿-Delegation
- Kotlin草稿-Field
- Kotlin草稿-object
- 4-JavaScript
- 5-Python
- 6-Other
- Git
- Gradle
- Android中ProGuard配置和總結
- gradle使用筆記
- Nexus私服搭建
- 編譯提速最佳實踐
- 7-設計模式與架構
- 組件化
- 組件化探索(OKR)
- 1-參考列表
- 2-1-組件化概述
- 2-2-gradle配置
- 2-3-代碼編寫
- 2-4-常見問題
- 2-9-值得一讀
- 8-數據結構與算法
- 0臨時文件
- 漢諾塔
- 8-數據-1數據結構
- HashMap
- HashMap、Hashtable、HashSet 和 ConcurrentHashMap 的比較
- 遲到一年HashMap解讀
- 8-數據-2算法
- 1個就夠了
- Java常用排序算法(必須掌握的8大排序算法)
- 常用排序算法總結(性能+代碼)
- 必須知道的八大種排序算法(java實現)
- 9-職業
- 閱讀
- 書單
- 面試
- 面試-01-java
- Java面試題全集駱昊(上)
- Java面試題全集駱昊(下)
- Java面試題全集駱昊(中)
- 面試-02-android
- 40道Android面試題
- 面試-03-開源源碼
- Android圖片加載框架最全解析(二),從源碼的角度理解Glide的執行流程
- 面試-07-設計模式
- 面試-08-算法
- 面試-09-其他
- SUMMARY
- 版權說明
- temp111