Java 集合

Java集合分4種體系:Set List Queue Map
集合與數(shù)組的區(qū)別:集合可以保存數(shù)量不定的數(shù)據(jù);集合可以保存有映射關系的數(shù)據(jù);集合只能保存對象(對象的引用變量),而數(shù)組可以保存對象,也可以是基本類型的值。
所有集合的類均位于java.util包下。
Java集合類主要由兩個接口派生出:Collection(Set,Queue,List) , Map(Map) 其實現(xiàn)類繼承樹如下(黃色背景是常用的類):

Collection接口繼承樹.png
Map接口繼承樹

Collection和Iterator接口
Collection接口里定義了如下方法:

Collection接口包含方法

Collection接口的所有實現(xiàn)類均重寫了toString()方法,所以用System.out.println()可打印集合全部的元素,如果要依次訪問集合元素,需使用某種方法來遍歷:

(1)使用Lambda表達式遍歷集合:
從Collection繼承樹可以看出,Collection實現(xiàn)了Iterable接口,而Iterable接口中有一個forEach(Consumer action)默認方法,該方法所需參數(shù)類型是函數(shù)式接口,故可用Lambda表達式來實現(xiàn)。
當程序調用forEach(Consumer action)遍歷集合元素時,程序會一次將集合元素傳給Consumer 的accept(T t)方法(接口中唯一的抽象方法)。

import java.util.Collection;
import java.util.HashSet;
//import java.util.Iterable;
public class CollectionEach 
{
    public static void main(String[] args) 
    {
        Collection students = new HashSet();
        students.add("張三");
        students.add("李四");
        students.add("王二");
        System.out.println("班級有 "+students.size()+" 個學生,他們分別是:");
        students.forEach(obj->System.out.println(obj+"同學"));
    }
}

(2)使用Iterator遍歷集合元素
Iterator接口主要用于遍歷Collection接口,Iterator對象也被稱為迭代器,它必須依附Collection對象。Iterator僅是遍歷集合,并不能提供盛裝對象的能力,所以如果在迭代器里進行增加元素操作,則無效。Iterator接口里定義了4個方法:

boolean hasNext(): 如果被迭代的集合元素還沒有被遍歷完,則返回true
Object next(): 返回集合里的下一個元素
void remove(): 刪除集合里上一次next()返回的元素
void forEachRemaining(Consumer action): 可以使用Lambda表達式來遍歷集合元素

import java.util.Collection;
import java.util.Iterator;
import java.util.HashSet;
class IteratorTest
{
public static void main(String[] args)
{
Collection books = new HashSet();
books.add("xx1");
books.add("xx2");
books.add("xx3");
Iterator it = books.iterator();
//獲取集合對應的迭代器
while (it.hasNext())
{
String book = (String)it.next();
//next()返回的是OBject故需強制轉換
System.out.println(book);
if (book.equals("xx2"))
{
it.remove();//注意此處不是books.remove(),迭代過程中不能對
//集合進行修改,否則會報錯。
}
book = "yy1";
}
System.out.println(books);//里面并沒有增加yy1
}
}

>(3)用Lambda表達式來遍歷Iterator
由(2)中可知,Iterator中有一個forEachRemaining(Consumer action)的方法,Consumer是一個函數(shù)式的接口,故可以用Lambda表達式來遍歷集合元素,當Iterator調用forEachRemaining(Consumer action)時,程序會依次將集合元素依次傳給Consumer 的accept(T t)方法。

import java.util.Collection;
import java.util.HashSet;
import java.util.Iterator;
public class IteratorEach
{
public static void main(String[] args)
{
System.out.println("Hello World!");
Collection books = new HashSet();
books.add("English");
books.add("math");
books.add("Chinese");
books.add("physics");
Iterator it = books.iterator();
it.forEachRemaining(obj -> System.out.println("迭代集合元素" + obj));
}
}

>(4)使用foreach循環(huán)來遍歷集合元素

import java.util.Collection;
import java.util.HashSet;
import java.util.Iterator;
public class IteratorEach
{
public static void main(String[] args)
{
System.out.println("Hello World!");
Collection books = new HashSet();
books.add("English");
books.add("math");
books.add("Chinese");
books.add("physics");
for(Object obj : books)
{
String book = (String)obj;//book變量不是集合元素本身
System.out.println(book);
if (book.equals("English"))
{
books.remove(book);//將引發(fā)異常,和Iterator迭代器一樣,
//訪問集合時,也不能直接改變集合。
}
}
System.out.println(books);
}
}

>(5)java8新增的Predicate集合過濾方法
removeIf(Predicate filter)方法:批量刪除符合Filter條件的元素。
Predicate(謂詞)接口:表示動作,是一個函數(shù)式接口

import java.util.Collection;
import java.util.HashSet;
import java.util.Iterator;
import java.util.function.Predicate;
public class IteratorEach
{
public static void main(String[] args)
{
System.out.println("Hello World!");
Collection books = new HashSet();
books.add("English");
books.add("math");
books.add("Chinese");
books.add("physics");
books.removeIf(ele ->((String)ele).length()<5);
System.out.println(books);
System.out.println(calAll(books,ele->((String)ele).contains("e")));
}
public static int calAll(Collection books,Predicate p)
{
int total = 0;
for (Object obj : books )
{
if (p.test(obj))
{
total ++;
}
}
return total;
}
}

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

友情鏈接更多精彩內容