java中set和get用法 javaset集合的值可以排序嗎?
javaset集合的值可以排序嗎?我們知道集合是無序的,可以使用TreeSet類。樹集排序的規(guī)則是什么?1treeset支持兩種排序方法:自然排序和自定義排序。默認情況下,TreeSet采用自然排序。
javaset集合的值可以排序嗎?
我們知道集合是無序的,可以使用TreeSet類。樹集排序的規(guī)則是什么?1treeset支持兩種排序方法:自然排序和自定義排序。默認情況下,TreeSet采用自然排序。自然排序:TreeSet調(diào)用set元素的CompareTo(objectobj)方法來比較元素的大小為什么set元素有CompareTo方法?因為set element對象實現(xiàn)了可比較的接口。此方法返回一個整數(shù)值。當一個對象調(diào)用此方法時,它會與另一個對象進行比較。例如,obb1。CompareTo(obb2)如果返回0,則表示兩個對象相等,例如如果該方法返回正整數(shù),則表示obji1大于obji2。如果該方法返回負整數(shù),則表示obji1小于obji2,因此需要使用TreeSet集合進行自然排序,并且元素必須實現(xiàn)可比較接口。但是,一些常見的Java類已經(jīng)實現(xiàn)了該接口,例如:stringcharacterboolean datetimebigdecimalbiginteger等,例如:TreeSet<string>Ts=new reeSet<string>()ts.添加(“b”)ts.添加(“c”)ts.添加(“a”)系統(tǒng)輸出打?。═S)結果:ABCjava.util文件
在包裝中,設置,列表和映射是接口。集合中的對象沒有按特定方式排序,并且沒有重復的對象。但是它的一些實現(xiàn)類可以用特定的方式對集合中的對象進行排序,比如TreeSet類,它可以在默認情況下或通過實現(xiàn)進行排序java.util.Comparator比較程序
接口定義排序方法。列表中的對象根據(jù)索引位置排序,可以有重復的對象,并且可以根據(jù)集合中對象的索引位置檢索對象,例如列表.獲取(i) 方法獲取列表集合中的元素。映射中的每個元素都包含一個鍵對象和一個值對象,它們成對出現(xiàn)。鍵對象不能復制,值對象可以復制。map的功能和方法:method put(object key,object value)添加一個“value”(你想要什么)和一個與“value”關聯(lián)的“key”(用它來查找)。方法get(objectkey)返回與給定鍵關聯(lián)的值。您可以使用containskey()和containsvalue()來測試映射是否包含“鍵”或“值”。標準Java類庫包含幾個不同的映射:HashMap、treemap、LinkedHashMap、weakhashmap、identityhashmap。它們具有相同的基本接口圖,但在行為、效率、排序策略、保存對象的生命周期、確定“鍵”等價性的策略等方面有所不同。執(zhí)行效率是map的一個大問題。如果您看看get()的作用,就會明白為什么在ArrayList中搜索“keys”相當慢。這就是HashMap加速的地方。HashMap使用一個稱為哈希碼的特殊值,而不是緩慢地搜索鍵。哈希代碼是一個相對唯一的int值,用于表示對象。它是通過轉換對象的某些信息而生成的。所有Java對象都可以生成哈希代碼,因為hashcode()是在基類對象中定義的方法。