一個快速、輕量級 Collection 庫 Trove

  Trove一個快速、輕量級針對java原子類型(byte,int,float,long等)的Collection 類的集合。其官方網站:http://trove.starlight-systems.com/home。java

 

據官方介紹,Trove有兩個目標,其一是提供免費的、快速的、輕量級的java Collections API的一個實現。這些實現被設計爲可替換對jdk集合代碼的使用。其二是提供針對原子類型的集合。在jdk中主要是經過原子類型的包括類型如Integer,Long等,再配合面向對象的集合來實現。如在jdk中若是須要使用int類型的集合,通常都是int的包裝類Integer結合List或者其它的集合類。在大多數應用程序中,使用存儲原子類型的集合,會減小對內存的使用,同時也不會對性能帶來損失。android

 

最近在閱讀一個開源的android項目源碼時,發現其中使用到了這個庫,google了一番,發現是個好東西,隨記下來以備後用。ide

 

這寫幾個簡單的例子:性能

一、支持int類型的List:TIntArrayList網站

 

Java代碼 複製代碼 收藏代碼
  1. public class IntList {
  2. public static void main(String[] args) {
  3. TIntArrayList intList = new TIntArrayList();
  4. intList.add(1);
  5. intList.add(6);
  6. intList.add(3);
  7. intList.add(2);
  8.  
  9. for (int i=0;i<intList.size();i++) {
  10. System.out.println(intList.get(i));
  11. }
  12.  
  13. intList.transformValues(new TIntFunction() {
  14. @Override
  15. public int execute(int v) {
  16. return v * 2;
  17. }
  18. });
  19. System.out.println(intList.toString());
  20.  
  21. intList.sort();
  22.  
  23. System.out.println(intList.toString());
  24.  
  25. int[] arr = intList.toArray();
  26. for (int i=0;i<arr.length;i++) {
  27. System.out.println(arr[i]);
  28. }
  29.  
  30. }
  31. }

執行結果:google


1
6
3
2
{2, 12, 6, 4}
{2, 4, 6, 12}
2
4
6
12

 

經過上面的代碼示例,能夠發現使用方式和jdk提供的集合使用方式一致,這也許就是trove說的,能夠用來替換對jdk集合的使用了。這裏它還提供了一些特殊的方法,好比transformValues,這個方法能夠根據你提供的TIntFunction來對TIntArrayList內部的值進行轉換。好比它還支持對內部元素直接排序,以及重載了toString方法,直接返回內部的元素。url

 

二、再看一個簡單的支持int,int的map:spa

 

Java代碼 複製代碼 收藏代碼
  1. import gnu.trove.map.TIntIntMap;
  2. import gnu.trove.map.hash.TIntIntHashMap;
  3.  
  4. public class IntMap {
  5. public static void main(String[] args) {
  6. TIntIntMap intMap = new TIntIntHashMap();
  7.  
  8. intMap.put(0, 10);
  9. intMap.put(1, 10);
  10. intMap.put(2, 20);
  11. intMap.put(3, 30);
  12.  
  13. System.out.println(intMap.get(0));
  14. System.out.println(intMap.get(1));
  15. System.out.println(intMap.get(2));
  16. System.out.println(intMap.get(3));
  17.  
  18. }
  19. }

執行結果:設計

10
10
20
30

記得之前寫代碼的時候,但願能有一個支持int到int的map,可是在沒有更好的選擇以前,只能選擇使用Integer來實現,不過之後能夠使用這個庫了。trove提供了int到byte,int到float,int到long等多種map。code

 

暫時介紹到這了,後面有使用到再接着寫!

相關文章
相關標籤/搜索