Guava學習筆記:Range
在Guava中新增了一個新的型別Range,從名字就可以瞭解到,這個是和區間有關的資料結構。從Google官方文件可以得到定義:Range定義了連續跨度的範圍邊界,這個連續跨度是一個可以比較的型別(Comparable type)。比如1到100之間的整型資料。
在數學裡面的範圍是有邊界和無邊界之分的;同樣,在Guava中也有這個說法。如果這個範圍是有邊界的,那麼這個範圍又可以分為包括開集(不包括端點)和閉集(包括端點);如果是無解的可以用+∞表示。如果列舉的話,一共有九種範圍表示:
概念 | 表示範圍 | guava對應功能方法 |
(a..b) |
{x | a < x < b} | open(C, C) |
[a..b] | {x | a <= x <= b} | closed(C, C) |
[a..b) | {x | a <= x < b} | closedOpen(C, C) |
(a..b] | {x | a < x <= b} | openClosed(C, C) |
(a..+∞) | {x | x > a} | greaterThan(C) |
[a..+∞) | {x | x >= a} | atLeast(C) |
(-∞..b) | {x | x < b} | lessThan(C) |
(-∞..b] | {x | x <= b} | atMost(C) |
(-∞..+∞) | all values | all() |
上表中的guava對應功能方法那一欄表示Range類提供的方法,分別來表示九種可能出現的範圍區間。如果區間兩邊都存在範圍,在這種情況下,區間右邊的數不可能比區間左邊的數小。在極端情況下,區間兩邊的數是相等的,但前提條件是最少有一個邊界是閉集的,否則是不成立的。比如:
[a..a] : 裡面只有一個數a;
[a..a); (a..a] : 空的區間範圍,但是是有效的;
(a..a) : 這種情況是無效的,構造這樣的Range將會丟擲異常。
在使用Range時需要注意:在構造區間時,儘量使用不可改變的型別。如果你需要使用可變的型別,在區間型別構造完成的情況下,請不要改變區間兩邊的數。
例項:
public class TestBaseRange {
@Test public void testRange(){ System.out.println("open:"+Range.open(1, 10)); System.out.println("closed:"+ Range.closed(1, 10)); System.out.println("closedOpen:"+ Range.closedOpen(1, 10)); System.out.println("openClosed:"+ Range.openClosed(1, 10)); System.out.println("greaterThan:"+ Range.greaterThan(10)); System.out.println("atLeast:"+ Range.atLeast(10)); System.out.println("lessThan:"+ Range.lessThan(10)); System.out.println("atMost:"+ Range.atMost(10)); System.out.println("all:"+ Range.all()); System.out.println("closed:"+Range.closed(10, 10)); System.out.println("closedOpen:"+Range.closedOpen(10, 10)); //會丟擲異常 System.out.println("open:"+Range.open(10, 10)); } }
此外,範圍可以構造例項通過繫結型別顯式,例如:
public class TestBaseRange { @Test public void testRange(){ System.out.println("downTo:"+Range.downTo(4, BoundType.OPEN)); System.out.println("upTo:"+Range.upTo(4, BoundType.CLOSED)); System.out.println("range:"+Range.range(1, BoundType.CLOSED, 4, BoundType.OPEN)); } }
輸出:
downTo:(4‥+∞) upTo:(-∞‥4] range:[1‥4)
操作方法
1.contains:判斷值是否在當前Range內
@Test public void testContains(){ System.out.println(Range.closed(1, 3).contains(2)); System.out.println(Range.closed(1, 3).contains(4)); System.out.println(Range.lessThan(5).contains(5)); System.out.println(Range.closed(1, 4).containsAll(Ints.asList(1, 2, 3))); } //=====輸出===== true false false true
2.Endpoint相關查詢方法:
@Test public void testQuery(){ System.out.println("hasLowerBound:"+Range.closedOpen(4, 4).hasLowerBound()); System.out.println("hasUpperBound:"+Range.closedOpen(4, 4).hasUpperBound()); System.out.println(Range.closedOpen(4, 4).isEmpty()); System.out.println(Range.openClosed(4, 4).isEmpty()); System.out.println(Range.closed(4, 4).isEmpty()); // Range.open throws IllegalArgumentException //System.out.println(Range.open(4, 4).isEmpty()); System.out.println(Range.closed(3, 10).lowerEndpoint()); System.out.println(Range.open(3, 10).lowerEndpoint()); System.out.println(Range.closed(3, 10).upperEndpoint()); System.out.println(Range.open(3, 10).upperEndpoint()); System.out.println(Range.closed(3, 10).lowerBoundType()); System.out.println(Range.open(3, 10).upperBoundType()); } //======輸出======= hasLowerBound:true hasUpperBound:true true true false 3 3 10 10 CLOSED OPEN
3.encloses方法:encloses(Range range)中的range是否包含在需要比較的range中
@Test public void testEncloses(){ Range<Integer> rangeBase=Range.open(1, 4); Range<Integer> rangeClose=Range.closed(2, 3); Range<Integer> rangeCloseOpen=Range.closedOpen(2, 4); Range<Integer> rangeCloseOther=Range.closedOpen(2, 5); System.out.println("rangeBase: "+rangeBase+" Enclose:"+rangeBase.encloses(rangeClose)+" rangeClose:"+rangeClose); System.out.println("rangeBase: "+rangeBase+" Enclose:"+rangeBase.encloses(rangeCloseOpen)+" rangeClose:"+rangeCloseOpen); System.out.println("rangeBase: "+rangeBase+" Enclose:"+rangeBase.encloses(rangeCloseOther)+" rangeClose:"+rangeCloseOther); } //=======輸出======== rangeBase: (1‥4) Enclose:true rangeClose:[2‥3] rangeBase: (1‥4) Enclose:true rangeClose:[2‥4) rangeBase: (1‥4) Enclose:false rangeClose:[2‥5)
4.isConnected:range是否可連線上
@Test public void testConnected(){ System.out.println(Range.closed(3, 5).isConnected(Range.open(5, 10))); System.out.println(Range.closed(0, 9).isConnected(Range.closed(3, 4))); System.out.println(Range.closed(0, 5).isConnected(Range.closed(3, 9))); System.out.println(Range.open(3, 5).isConnected(Range.open(5, 10))); System.out.println(Range.closed(1, 5).isConnected(Range.closed(6, 10))); } //======輸出========= true true true false false
4.intersection:如果兩個range相連時,返回最大交集,如果不相連時,直接丟擲異常
@Test public void testIntersection(){ System.out.println(Range.closed(3, 5).intersection(Range.open(5, 10))); System.out.println(Range.closed(0, 9).intersection(Range.closed(3, 4))); System.out.println(Range.closed(0, 5).intersection(Range.closed(3, 9))); System.out.println(Range.open(3, 5).intersection(Range.open(5, 10))); System.out.println(Range.closed(1, 5).intersection(Range.closed(6, 10))); } //=======輸出========= (5‥5] [3‥4] [3‥5] 注意:第四和第五行程式碼,當集合不相連時,會直接報錯
5.span:獲取兩個range的並集,如果兩個range是兩連的,則是其最小range
@Test public void testSpan(){ System.out.println(Range.closed(3, 5).span(Range.open(5, 10))); System.out.println(Range.closed(0, 9).span(Range.closed(3, 4))); System.out.println(Range.closed(0, 5).span(Range.closed(3, 9))); System.out.println(Range.open(3, 5).span(Range.open(5, 10))); System.out.println(Range.closed(1, 5).span(Range.closed(6, 10))); System.out.println(Range.closed(1, 5).span(Range.closed(7, 10))); } //=====輸出======= true true true false false
相關推薦
Guava學習筆記:Range
在Guava中新增了一個新的型別Range,從名字就可以瞭解到,這個是和區間有關的資料結構。從Google官方文件可以得到定義:Range定義了連續跨度的範圍邊界,這個連續跨度是一個可以比較的型別(Comparable type)。比如1到100之間的整型資料。 在數學裡面的範圍是有邊界和無邊界之分
Guava學習筆記:Optional優雅的使用null
asset 不包含 你在 rgs 命名 靜態 不清晰 ces throw 在我們學習和使用Guava的Optional之前,我們需要來了解一下Java中null。因為,只有我們深入的了解了null的相關知識,我們才能更加深入體會領悟到Guava的Optional設計和使用上
python學習筆記: range()函式、算數運算子“//”,迴圈while與for
range() 函式——可建立一個整數列表,一般用在 for 迴圈中,函式語法:range(start, stop[, step]) start: 計數從 start 開始。預設是從 0 開始。例如range(5)等價於range(0, 5); stop: 計數到 stop 結束,但
Guava學習筆記:Guava cache
快取,在我們日常開發中是必不可少的一種解決效能問題的方法。簡單的說,cache 就是為了提升系統性能而開闢的一塊記憶體空間。 快取的主要作用是暫時在記憶體中儲存業務系統的資料處理結果,並且等待下次訪問使用。在日常開發的很多場合,由於受限於硬碟IO的效能或者我們自
Guava學習筆記:Preconditions優雅的檢驗引數
在日常開發中,我們經常會對方法的輸入引數做一些資料格式上的驗證,以便保證方法能夠按照正常流程執行下去。對於可預知的一些資料上的錯誤,我們一定要做事前檢測和判斷,來避免程式流程出錯,而不是完全通過錯誤處理來保證流程正確執行,畢竟錯誤處理是比較消耗資源的方式。在平常情況下我們對引數的判斷都需要自己來逐個寫方法
Guava學習筆記:Guava新集合-Table等
Table 當我們需要多個索引的資料結構的時候,通常情況下,我們只能用這種醜陋的Map<FirstName, Map<LastName, Person>>來實現。為此Guava提供了一個新的集合型別-Table集合型別,來支援這種資料結構的使用場景。Table支援“row”和“
Guava學習筆記:Guava新增集合型別-Multiset
Guava引進了JDK裡沒有的,但是非常有用的一些新的集合型別。所有這些新集合型別都能和JDK裡的集合平滑整合。Guava集合非常精準地實現了JDK定義的介面。Guava中定義的新集合有: Multiset SortedMultiset Multimap ListMultimap SetMult
Guava學習筆記:Guava新增集合型別-Multimap
在日常的開發工作中,我們有的時候需要構造像Map<K, List<V>>或者Map<K, Set<V>>這樣比較複雜的集合型別的資料結構,以便做相應的業務邏輯處理。例如: import java.util.ArrayList; import java
Guava學習筆記:Immutable(不可變)集合
不可變集合,顧名思義就是說集合是不可被修改的。集合的資料項是在建立的時候提供,並且在整個生命週期中都不可改變。 為什麼要用immutable物件?immutable物件有以下的優點: 1.對不可靠的客戶程式碼庫來說,它使用安全,可以在未受信任的類庫中安全的使用這些物件 2.執行緒安全
Guava學習筆記:EventBus
EventBus是Guava的事件處理機制,是設計模式中的觀察者模式(生產/消費者程式設計模型)的優雅實現。對於事件監聽和釋出訂閱模式,EventBus是一個非常優雅和簡單解決方案,我們不用建立複雜的類和介面層次結構。 Observer模式是比較常用的設計模式之一,雖然有時候在具體程式碼裡,它不一定
Guava學習筆記:複寫的Object常用方法
在Java中Object類是所有類的父類,其中有幾個需要override的方法比如equals,hashCode和toString等方法。每次寫這幾個方法都要做很多重複性的判斷, 很多類庫提供了覆寫這幾個方法的工具類, Guava也提供了類似的方式。下面我們來看看Guava中這幾個方法簡單使用。 e
Guava學習筆記:簡化異常處理的Throwables類
有時候, 當我們我們捕獲異常, 並且像把這個異常傳遞到下一個try/catch塊中。Guava提供了一個異常處理工具類, 可以簡單地捕獲和重新丟擲多個異常。例如: import java.io.IOException; import org.junit.Test; import com.goog
Guava學習筆記:Guava新增集合型別-Bimap
BiMap提供了一種新的集合型別,它提供了key和value的雙向關聯的資料結構。 通常情況下,我們在使用Java的Map時,往往是通過key來查詢value的,但是如果出現下面一種場景的情況,我們就需要額外編寫一些程式碼了。首先來看下面一種表示標識序號和檔名的map結構。 @Test
Guava學習筆記:Ordering犀利的比較器
Ordering是Guava類庫提供的一個犀利強大的比較器工具,Guava的Ordering和JDK Comparator相比功能更強。它非常容易擴充套件,可以輕鬆構造複雜的comparator,然後用在容器的比較、排序等操作中。 本質上來說,Ordering 例項無非就是一個特殊的Comparat
python學習筆記:range()函式用法
>>> range(1,5) #代表從1到5(不包含5) [1, 2, 3, 4] >>> range(1,5,2) #代表從1到5,間隔2(不包含5) [
Guava學習筆記(二):基礎(Joiner,Objects,Splitter及Strings)
nonnull obj expect null dto 字符 情況 core cte 添加Maven依賴 JoinerTest import com.google.common.base.Joiner; import org.junit.Assert; import org
Python學習筆記:python3中的range()函式的返回物件型別
在python3中 print(range(10)) range(0,10) 得出的結果是 range(0,10) ,而不是[0,1,2,3,4,5,6,7,8,9] ,為什麼呢? 而且原來Python2版本中的xrange也已經取消。 官網原話: In many ways the object re
Guava學習筆記(二):Google Guava (瓜娃)的API快速熟悉使用
1,大綱 讓我們來熟悉瓜娃,並體驗下它的一些API,分成如下幾個部分: IntroductionGuava Collection APIGuava Basic UtilitiesIO APICache API 2,為神馬選擇瓜娃? 瓜娃是java API蛋糕上的冰
Linux學習筆記:存儲管理
linux 磁盤管理 Linux系統中所有的硬件設備都是通過文件的方式來表現和使用的,我們將這些文件稱為設備文件,在Linux下的/dev目錄中有大量的設備文件,根據設備文件的不同,又分為字符設備文件和塊設備文件。字符設備文件的存取是以字符流的方式來進行的,一次傳送一個字符。常見的有打印
學習筆記:javascript內置對象:數組對象
b- sort splice 刪除 分隔 href 結果 join() strong 1.數組對象的創建 1.設置一個長度為0的數組 var myarr=new array(); 2.設置一個長度為n的數組 var myarr=new arr(n); 3.聲明一個