Java List接口的集合使用詳解
List接口繼承collection接口,此接口可以對列表中的每個元素精確的控制,可以根據元素的索引來獲取列表中的值,下面介紹常用的幾種,ArrayList,LinkedList。
ArrayList集合
ArrayList是一個動態修改的數組,它沒有固定的大小,不需要自己分配空間,java本身已經初始化容量為10的大小,可以直接添加刪除等一系列操作。
ArrayList構造方法:
- ArrayList() ;構造一個初始化容量為10的空列表。
- ArrayList(Collection c) ; 構造一個包含指定 collection 的元素的列表,這些元素是按照該 collection 的迭代器返回它們的順序排列的。
- ArrayList(int initialCapacity) ;構造一個指定初始容量的空列表。
常用方法:
方法名 | 說明 |
---|---|
boolean add(E e) | 將指定元素添加到列表尾部 |
void add(int index, E element) | 將指定元素添加到列表中指定位置 |
void clear() | 刪除此列表中的所有元素 |
Object clone() | 返回ArrayList副本 |
boolean contains(Object o) | 如果列表中包含指定元素則返回true,否則false |
E get(int index) | 返回列表中指定索引位置上的元素 |
int indexOf(Object o) | 返回列表中首次出現的指定元素的索引,如果沒有則返回-1 |
int lastIndexOf(Object o) | 返回此列表中最後一次出現的指定元素的索引,沒有則返回-1 |
E remove(int index) | 刪除指定索引上的元素,並返回刪除值 |
boolean remove(Object o) | 移除列表中首次出現的元素 |
E set(int index, E element) | 將此列表中的索引位置的元素換成指定的元素 |
int size() | 返回此列表中的元素個數 |
Object[] toArray() | 將此列表所有元素換成數組 |
boolean isEmpty() | 如果此列表為空則返回true |
List subList(int fromlndex, int tolndex) | 將此列表中從fromindex到toindex的元素組成新的集合返回 |
示例
import java.util.ArrayList; public class dome2{ public static void main(String[] args){ ArrayList list=new ArrayList(); list.add("nihoa"); //添加字符串 list.add(12); //添加數字 list.add('a'); //添加字符 list.add("hello"); list.set(1,"java"); //將索引為1的換成字符串 System.out.println("索引為2的值是:"+list.get(2)); System.out.println("刪除索引為0的值是:"+list.remove(0)); System.out.println("列表中還有"+list.size()+"個元素"); System.out.println("判斷列表是不是為空: "+list.isEmpty()); for (Object object : list) { //循序打印 System.out.print(object+" "); } } }
結果
索引為2的值是:a
刪除索引為0的值是:nihoa
列表中還有3個元素
判斷列表是不是為空: false
java a hello
例1:
創建一個商品類,指定商品的編號,名稱,價格,封裝它們。
class Goods{ private int id; //編號 private String name; //名稱 private float price; //價格 public Goods() { } public Goods(int id, String name, float price) { super(); this.id = id; this.name = name; this.price = price; } public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public float getPrice() { return price; } public void setPrice(float price) { this.price = price; } @Override public String toString() { //格式輸出 return "商品編號: "+id+", 名稱: "+", 價格: "+","; } }
創建一個測試類,填寫商品的價格,編號,名稱並保存到列表中,通過ArrayList類的方法修改和獲取值。
import java.util.ArrayList; public class dome2{ public static void main(String[] args){ ArrayList<Goods> list=new ArrayList<Goods>(); list.add(new Goods(1,"保溫杯",22.0f)); list.add(new Goods(2,"洗發水",21.3f)); list.add(new Goods(3,"筆記本",5.0f)); Goods g=new Goods(5,"熱水壺",59.0f); list.add(g); list.add(new Goods(4,"菜刀",31.4f)); //1.遍歷所有商品 for(int i=0;i<list.size();i++) { System.out.println(list.get(i).toString()); } //2.獲取指定商品的信息 System.out.println("查找編號為3,名稱為熱水壺,價格為59元的元素索引"+list.indexOf(g)); System.out.println("熱水壺的價格是 "+list.get(3).getPrice()+" 元"); System.out.println("洗發水的編號是 "+list.get(1).getId()); System.out.println("將菜刀的價格設為120元 "); list.get(list.size()-1).setPrice(120.0f); //3.遍歷所有商品 for(int i=0;i<list.size();i++) { System.out.println(list.get(i).toString()); } } }
結果
商品編號: 1 名稱: 保溫杯 價格: 22.0
商品編號: 2 名稱: 洗發水 價格: 21.3
商品編號: 3 名稱: 筆記本 價格: 5.0
商品編號: 5 名稱: 熱水壺 價格: 59.0
商品編號: 4 名稱: 菜刀 價格: 31.4
查找編號為3,名稱為熱水壺,價格為59元的元素索引3
熱水壺的價格是 59.0 元
洗發水的編號是 2
將菜刀的價格設為120元
商品編號: 1 名稱: 保溫杯 價格: 22.0
商品編號: 2 名稱: 洗發水 價格: 21.3
商品編號: 3 名稱: 筆記本 價格: 5.0
商品編號: 5 名稱: 熱水壺 價格: 59.0
商品編號: 4 名稱: 菜刀 價格: 120.0
Iterator迭代器遍歷:
Iterator接口是Collection接口的超級接口,通過Collection接口下的iterator方法返回iterator。
Iterator方法:
方法名 | 說明 |
---|---|
boolean hasNext() | 如果有元素仍可以迭代,就返回true |
E next() | 返回迭代的下一個元素 |
void remove() | 移除迭代器返回的最後一個元素 |
public class dome2{ public static void main(String[] args){ ArrayList list=new ArrayList(); list.add("hello "); list.add("world!,"); list.add("hello "); list.add("java!"); Iterator it=list.iterator(); while(it.hasNext()) { //判斷是否還有下一個元素 System.out.print(it.next()); //輸出下一個元素 } } }
LinkedList類
LinkedList類采用鏈表結構保存對象,鏈表采用節點之間的指向,上一個節點指向下一個節點,並且可以在中間插入,不需要數組還需要重新排列,所以在頻繁的插入元素和刪除元素這方面,LinkedList類要比ArrayList類要快,效率更高。但在訪問元素速度方面卻相對落後。
構造方法
- LinkedList() ;構造一個空列表
- LinkedList(Collection c) ;構造一個包含指定 collection 中的元素的列表
常用方法:
方法名 | 說明 |
---|---|
boolean add(E e) | 將指定元素添加到元素列表的結尾 |
void add(int index, E element) | 在列表中指定的位置插入指定的元素 |
void addFirst(E e) | 將指定元素插入到此列表的開頭 |
void addLast(E e) | 將指定的元素添加到此列表的結尾 |
boolean contains(Object o) | 如果列表中有指定元素返回true,否則false |
E element() | 獲取但不移除此列表的第一個元素 |
E get(int index) | 返回此列表中指定的元素 |
E getFirst() | 返回此列表的第一個元素 |
E getLast() | 返回此列表的最後一個元素 |
int indexOf(Object o) | 返回此列表首次出現的指定元素的索引,沒有返回-1 |
int lastIndexOf(Object o) | 返回此列表最後出現的指定元素的索引,沒有返回-1 |
E set(int index, E element) | 將列表中指定位置的元素替換 |
E removeFirst() | 移除並返回此列表中的第一個元素 |
E removeLast() | 移除並返回此列表的最後一個元素 |
示例:
public class dome2{ public static void main(String[] args){ LinkedList list=new LinkedList(); list.add("電風扇"); list.add("吹風機"); list.add("香皂"); list.add("肥皂"); list.add("洗發水"); System.out.println("獲取的第一個商品是: "+list.getFirst()); System.out.println("獲取的最後一個商品是: "+list.getLast()); System.out.println("刪除的第一個元素是: "+list.removeFirst()); System.out.println("將索引為3的元素修改成: "+list.set(3,"牛角梳")); for(int i=0;i<list.size();i++) { System.out.print(list.get(i)+"\t"); } } }
LinkedList與ArrayList的區別:
1.ArrayList類是基於數組結構實現的,訪問速度優先於LinkedList類。
2.LinkedList類占用的內存空間比較大,但在批量插入,刪除,修改等時優先於ArrayList類。
總結
本片文章就到這裡瞭,希望能夠給你帶來幫助,也希望您能夠多多關註WalkonNet的更多內容!
推薦閱讀:
- 一篇文章帶你入門java集合
- 簡單闡述一下Java集合的概要
- java集合collection接口與子接口及實現類
- 深入淺出講解Java集合之Collection接口
- Java集合的Collection接口和List接口詳解