一、簡介
Guava是一款由Google開發的Java工具庫,提供了一些優秀的、高效的、基於JDK的核心Java庫。
Guava-java庫的主要特點是它提供了很多高級的操作工具來簡化Java應用程序的開發過程,提供了更豐富、更強大的數據容器、函數式編程、並發工具、字符串處理、I/O操作等等。
Guava-java庫是Java應用程序開發中不可或缺的一個重要組件。
二、函數式編程
Guava提供了一些簡單而強大的函數式編程函數,它們有一些非常流行的函數,如Mappers和Predicates等。
Mappers函數是用於數據的轉換,通過使用Mappers可以在兩個不同的類型之間進行轉換。
Predicates函數是用於數據篩選的,並可用於編寫複雜的邏輯運算。
下面是一個示例代碼:
List<Integer> numbers = Lists.newArrayList(1, 2, 3, 4, 5); List<Integer> result = Lists.newArrayList( Iterables.filter(numbers, Predicates.not(Predicates.equalTo(3))));
三、數據容器
Guava具有豐富的數據容器,其中最熟悉的包括:Lists、Maps、Sets、Multisets、Multimaps等。
下面是一個示例代碼:
List<String> list = Lists.newArrayList("a", "b", "c", "a", "b", "c"); Multiset<String> count = HashMultiset.create(list); count.entrySet().forEach(entry -> { System.out.println(entry.getElement() + " count " + entry.getCount()); });
四、字符串處理
Guava提供了許多有用的字符串處理功能,包括許多複雜的算法和數據結構的實現。
下面是一個示例代碼:
String test = "I am looking through this glass door"; List<String> words = Splitter.on(" ").splitToList(test); String result = Joiner.on("|").join(words); System.out.println(result);
五、並發工具
Guava提供豐富的並發編程工具來簡化數據競爭問題的處理。
下面是一個示例代碼:
Executor executor = Executors.newFixedThreadPool(2); ListenableFutureTask<String> task1 = ListenableFutureTask.create(() -> "Task 1"); ListenableFutureTask<String> task2 = ListenableFutureTask.create(() -> "Task 2"); ListenableFuture<String> order1 = Futures.transformAsync(task1, (result) -> { System.out.println(Thread.currentThread().getName() + " " + result); return task2; }, executor); Futures.whenComplete(order1, (result, error) -> { System.out.println("1 " + result + " " + Thread.currentThread().getName()); System.out.println("2 " + error); }, executor); task1.run();
六、I/O操作
Guava提供了一些有用的I/O操作,包括一些簡單的、基於Java核心庫的操作和一些高級的、複雜的操作。
下面是一個示例代碼:
String filePath = "/path/to/your/file.txt"; List<String> lines = Files.readLines(new File(filePath), Charsets.UTF_8);
七、結語
本文對Guava-java提供的主要幾個特點進行了介紹,僅僅是對其強大功能的一個淺顯的闡述。如果您正在尋找一個全能的Java程序開發工具,則Guava-java將會是一個不錯的選擇。
完整的示例代碼:
package com.demo.guava; import com.google.common.base.Charsets; import com.google.common.base.Joiner; import com.google.common.base.Predicate; import com.google.common.base.Predicates; import com.google.common.collect.HashMultiset; import com.google.common.collect.Iterables; import com.google.common.collect.Lists; import com.google.common.collect.Multiset; import com.google.common.io.Files; import com.google.common.util.concurrent.Futures; import com.google.common.util.concurrent.ListenableFuture; import com.google.common.util.concurrent.ListenableFutureTask; import java.io.File; import java.io.IOException; import java.util.List; import java.util.concurrent.Executor; import java.util.concurrent.Executors; public class GuavaExample { public static void main(String[] args) throws IOException { // Functional Programming List numbers = Lists.newArrayList(1, 2, 3, 4, 5); List result = Lists.newArrayList( Iterables.filter(numbers, Predicates.not(Predicates.equalTo(3)))); System.out.println(result); // Data Containers List list = Lists.newArrayList("a", "b", "c", "a", "b", "c"); Multiset count = HashMultiset.create(list); count.entrySet().forEach(entry -> { System.out.println(entry.getElement() + " count " + entry.getCount()); }); // String Handling String test = "I am looking through this glass door"; List words = Splitter.on(" ").splitToList(test); String joinerResult = Joiner.on("|").join(words); System.out.println(joinerResult); // Concurrency Executor executor = Executors.newFixedThreadPool(2); ListenableFutureTask task1 = ListenableFutureTask.create(() -> "Task 1"); ListenableFutureTask task2 = ListenableFutureTask.create(() -> "Task 2"); ListenableFuture order1 = Futures.transformAsync(task1, (result) -> { System.out.println(Thread.currentThread().getName() + " " + result); return task2; }, executor); Futures.whenComplete(order1, (result, error) -> { System.out.println("1 " + result + " " + Thread.currentThread().getName()); System.out.println("2 " + error); }, executor); task1.run(); // I/O Operations String filePath = "/path/to/your/file.txt"; List lines = Files.readLines(new File(filePath), Charsets.UTF_8); } }
原創文章,作者:TPQOS,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/371307.html