欧美亚洲自拍偷拍_日本一区视频在线观看_国产二区在线播放_亚洲男人第一天堂

二維碼
企資網

掃一掃關注

當前位置: 首頁 » 企資快報 » 企業(yè) » 正文

工具篇_介紹幾個好用的guava工具類

放大字體  縮小字體 發(fā)布日期:2021-09-13 13:46:09    作者:啊丟    瀏覽次數:29
導讀

前言平時我們都會封裝一些處理緩存或其他的小工具。但每個人都封裝一次,重復造輪子,有點費時間。有沒有一些好的工具庫推薦-guava。guava是谷歌基于java封裝好的開源庫,它的性能、實用性,比我們自己造的輪子更好

前言

平時我們都會封裝一些處理緩存或其他的小工具。但每個人都封裝一次,重復造輪子,有點費時間。有沒有一些好的工具庫推薦-guava。guava是谷歌基于java封裝好的開源庫,它的性能、實用性,比我們自己造的輪子更好,畢竟谷歌出品,下面介紹下幾個常用的guava工具類

  • LoadingCache(本地緩存)
  • Multimap 和 Multiset
  • BiMap
  • Table(表)
  • Sets和Maps(交并差)
  • EventBus(事件)
  • StopWatch(秒表)
  • Files(文件操作)
  • RateLimiter(限流器)
  • Guava Retry(重試)

    關注公眾號,一起交流,微信搜一搜: 潛行前行

    guava的maven配置引入

    <dependency>  <groupId>com.google.guava</groupId>  <artifactId>guava</artifactId>  <version>27.0-jre</version> </dependency>復制代碼

    LoadingCache

  • LoadingCache 在實際場景中有著非常廣泛的使用,通常情況下如果遇到需要大量時間計算或者緩存值的場景,就應當將值保存到緩存中。LoadingCache 和 ConcurrentMap 類似,但又不盡相同。最大的不同是 ConcurrentMap 會永久的存儲所有的元素值直到他們被顯示的移除,但是 LoadingCache 會為了保持內存使用合理會根據配置自動將過期值移除
  • 通常情況下,Guava caching 適用于以下場景:
  • 花費一些內存來換取速度
  • 一些 key 會被不止一次被調用
  • 緩存內容有限,不會超過內存空間的值,Guava caches 不會存儲內容到文件或者到服務器外部,如果有此類需求考慮使用 Memcached, Redis
  • LoadingCache 不能緩存 null key
  • CacheBuilder 構造 LoadingCache 參數介紹

    CacheBuilder 方法參數

    描述

    initialCapacity(int initialCapacity)

    緩存池的初始大小

    concurrencyLevel(int concurrencyLevel)

    設置并發(fā)數

    maximumSize(long maximumSize)

    緩存池大小,在緩存項接近該大小時, Guava開始回收舊的緩存項

    weakValues()

    設置value的存儲引用是虛引用

    softValues()

    設置value的存儲引用是軟引用

    expireAfterWrite(long duration, TimeUnit unit)

    設置時間對象沒有被寫則對象從內存中刪除(在另外的線程里面不定期維護)

    expireAfterAccess(long duration, TimeUnit unit)

    設置時間對象沒有被讀/寫訪問則對象從內存中刪除(在另外的線程里面不定期維護)

    refreshAfterWrite(long duration, TimeUnit unit)

    和expireAfterWrite類似,不過不立馬移除key,而是在下次更新時刷新,這段時間可能會返回舊值

    removalListener( RemovalListener<? super K1, ? super V1> listener)

    監(jiān)聽器,緩存項被移除時會觸發(fā)

    build(CacheLoader<? super K1, V1> loader)

    當數據不存在時,則使用loader加載數據

  • LoadingCache V get(K key), 獲取緩存值,如果鍵不存在值,將調用CacheLoader的load方法加載新值到該鍵中
  • 示例
    LoadingCache<Integer,Long> cacheMap = CacheBuilder.newBuilder().initialCapacity(10)    .concurrencyLevel(10)    .expireAfterAccess(Duration.ofSeconds(10))    .weakValues()    .recordStats()    .removalListener(new RemovalListener<Integer,Long>(){        @Override        public void onRemoval(RemovalNotification<Integer, Long> notification) {            System.out.println(notification.getValue());        }    })    .build(new CacheLoader<Integer,Long>(){        @Override        public Long load(Integer key) throws Exception {            return System.currentTimeMillis();        }    });cacheMap.get(1);復制代碼

    Multimap 和 MultiSet

  • Multimap的特點其實就是可以包含有幾個重復Key的value,可以put進入多個不同value但是相同的key,但是又不會覆蓋前面的內容
  • 示例
    //Multimap: key-value  key可以重復,value也可重復Multimap<String, String> multimap = ArrayListMultimap.create();multimap.put("csc","1");multimap.put("lwl","1");multimap.put("csc","1");multimap.put("lwl","one");System.out.println(multimap.get("csc"));System.out.println(multimap.get("lwl"));---------------------------[1, 1][1, one]復制代碼
  • MultiSet 有一個相對有用的場景,就是跟蹤每種對象的數量,所以可以用來進行數量統(tǒng)計
  • 示例
    //MultiSet: 無序+可重復   count()方法獲取單詞的次數  增強了可讀性+操作簡單Multiset<String> set = HashMultiset.create();set.add("csc");set.add("lwl");set.add("csc");System.out.println(set.size());System.out.println(set.count("csc"));---------------------------32復制代碼

    BiMap

  • BiMap的鍵必須唯一,值也必須唯一,可以實現value和key互轉
  • 示例
    BiMap<Integer,String> biMap = HashBiMap.create();biMap.put(1,"lwl");biMap.put(2,"csc");BiMap<String, Integer> map = biMap.inverse(); // value和key互轉map.forEach((v, k) -> System.out.println(v + "-" + k));復制代碼

    Table

  • Table<R,C,V> table = HashbasedTable.create();,由泛型可以看出,table由雙主鍵R(行),C(列)共同決定,V是存儲值
  • 新增數據:table.put(R,C,V)
  • 獲取數據:V v = table.get(R,C)
  • 遍歷數據: Set<R> set = table.rowKeySet(); Set<C> set = table.columnKeySet();   
  • 示例
    // 雙鍵的Map Map--> Table-->rowKey+columnKey+value  Table<String, String, Integer> tables = HashbasedTable.create();tables.put("csc", "lwl", 1);//row+column對應的valueSystem.out.println(tables.get("csc","lwl"));復制代碼

    Sets和Maps

    // 不可變集合的創(chuàng)建ImmutableList<String> iList = ImmutableList.of("csc", "lwl");ImmutableSet<String> iSet = ImmutableSet.of("csc", "lwl");ImmutableMap<String, String> iMap = ImmutableMap.of("csc", "hello", "lwl", "world");復制代碼

    set的交集, 并集, 差集

    HashSet setA = newHashSet(1, 2, 3, 4, 5);  HashSet setB = newHashSet(4, 5, 6, 7, 8); //并集SetView union = Sets.union(setA, setB);   //差集 setA-setBSetView difference = Sets.difference(setA, setB);  //交集SetView intersection = Sets.intersection(setA, setB);  復制代碼

    map的交集,并集,差集

    HashMap<String, Integer> mapA = Maps.newHashMap();mapA.put("a", 1);mapA.put("b", 2);mapA.put("c", 3);HashMap<String, Integer> mapB = Maps.newHashMap();mapB.put("b", 20);mapB.put("c", 3);mapB.put("d", 4);MapDifference<String, Integer> mapDifference = Maps.difference(mapA, mapB);//mapA 和 mapB 相同的 entrySystem.out.println(mapDifference.entriesInCommon());//mapA 和 mapB key相同的value不同的 entrySystem.out.println(mapDifference.entriesDiffering());//只存在 mapA 的 entrySystem.out.println(mapDifference.entriesOnlyOnLeft());//只存在 mapB 的 entrySystem.out.println(mapDifference.entriesOnlyOnRight());;-------------結果-------------{c=3}{b=(2, 20)}{a=1}{d=4}復制代碼

    EventBus

  • EventBus是Guava的事件處理機制,是設計模式中的觀察者模式(生產/消費者編程模型)的優(yōu)雅實現。對于事件監(jiān)聽和發(fā)布訂閱模式
  • EventBus內部實現原理不復雜,EventBus內部會維護一個Multimap<Class<?>, Subscriber> map,key就代表消息對應的類(不同消息不同類,區(qū)分不同的消息)、value是一個Subscriber,Subscriber其實就是對應消息處理者。如果有消息發(fā)布就去這個map里面找到這個消息對應的Subscriber去執(zhí)行
  • 使用示例
    @Data@AllArgsConstructorpublic class OrderMessage {    String message;}//使用 @Subscribe 注解,表明使用dealWithEvent 方法處理 OrderMessage類型對應的消息//可以注解多個方法,不同的方法 處理不同的對象消息public class OrderEventListener {    @Subscribe    public void dealWithEvent(OrderMessage event) {        System.out.println("內容:" + event.getMessage());    }}-------------------------------------// new AsyncEventBus(String identifier, Executor executor);EventBus eventBus = new EventBus("lwl"); eventBus.register(new OrderEventListener());// 發(fā)布消息eventBus.post(new OrderMessage("csc"));復制代碼

    StopWatch

    Stopwatch stopwatch = Stopwatch.createStarted();for(int i=0; i<100000; i++){    // do some thing}long nanos = stopwatch.elapsed(TimeUnit.MILLISECONDS);System.out.println("邏輯代碼運行耗時:"+nanos);復制代碼

    Files文件操作

  • 數據寫入
    File newFile = new File("D:/text.txt");Files.write("this is a test".getBytes(), newFile);//再次寫入會把之前的內容沖掉Files.write("csc".getBytes(), newFile);//追加寫Files.append("lwl", newFile, Charset.defaultCharset());復制代碼
  • 文本數據讀取
    File newFile = new File("E:/text.txt");List<String> lines = Files.readLines(newFile, Charset.defaultCharset());復制代碼
  • 其他操作

    方法

    描述

    Files.copy(File from, File to)

    復制文件

    Files.deleteDirectoryContents(File directory)

    刪除文件夾下的內容(包括文件與子文件夾)

    Files.deleteRecursively(File file)

    刪除文件或者文件夾

    Files.move(File from, File to)

    移動文件

    Files.touch(File file)

    創(chuàng)建或者更新文件的時間戳

    Files.getFileExtension(String file)

    獲得文件的擴展名

    Files.getNameWithoutExtension(String file)

    獲得不帶擴展名的文件名

    Files.map(File file, MapMode mode)

    獲取內存映射buffer

    RateLimiter

    //RateLimiter 構造方法,每秒限流permitsPerSecondpublic static RateLimiter create(double permitsPerSecond) //每秒限流 permitsPerSecond,warmupPeriod 則是數據初始預熱時間,從第一次acquire 或 tryAcquire 執(zhí)行開時計算public static RateLimiter create(double permitsPerSecond, Duration warmupPeriod)//獲取一個令牌,阻塞,返回阻塞時間public double acquire()//獲取 permits 個令牌,阻塞,返回阻塞時間public double acquire(int permits)//獲取一個令牌,超時返回public boolean tryAcquire(Duration timeout)////獲取 permits 個令牌,超時返回public boolean tryAcquire(int permits, Duration timeout)復制代碼
  • 使用示例
    RateLimiter limiter = RateLimiter.create(2, 3, TimeUnit.SECONDS);System.out.println("get one permit cost time: " + limiter.acquire(1) + "s");System.out.println("get one permit cost time: " + limiter.acquire(1) + "s");System.out.println("get one permit cost time: " + limiter.acquire(1) + "s");System.out.println("get one permit cost time: " + limiter.acquire(1) + "s");System.out.println("get one permit cost time: " + limiter.acquire(1) + "s");System.out.println("get one permit cost time: " + limiter.acquire(1) + "s");System.out.println("get one permit cost time: " + limiter.acquire(1) + "s");System.out.println("get one permit cost time: " + limiter.acquire(1) + "s");---------------  結果 -------------------------get one permit cost time: 0.0sget one permit cost time: 1.331672sget one permit cost time: 0.998392sget one permit cost time: 0.666014sget one permit cost time: 0.498514sget one permit cost time: 0.498918sget one permit cost time: 0.499151sget one permit cost time: 0.488548s復制代碼
  • 因為RateLimiter滯后處理的,所以第一次無論取多少都是零秒
  • 可以看到前四次的acquire,花了三秒時間去預熱數據,在第五次到第八次的acquire耗時趨于平滑

    Guava Retry

  • maven引入
    <dependency>  <groupId>com.github.rholder</groupId>  <artifactId>guava-retrying</artifactId>  <version>2.0.0</version></dependency>復制代碼
  • RetryerBuilder 構造方法

    RetryerBuilder方法

    描述

    withRetryListener

    重試監(jiān)聽器

    withWaitStrategy

    失敗后重試間隔時間

    withStopStrategy

    停止策略

    withBlockStrategy

    阻塞策略BlockStrategy

    withAttemptTimeLimiter

    執(zhí)行時間限制策略

    retryIfException

    發(fā)生異常,則重試

    retryIfRuntimeException

    發(fā)生RuntimeException異常,則重試

    retryIfExceptionOfType(Class<? extends Throwable> ex)

    發(fā)生ex異常,則重試

    retryIfException(Predicate<Throwable> exceptionPredicate)

    對異常判斷,是否重試

    retryIfResult(Predicate<V> resultPredicate)

    對返回結果判斷,是否重試

    Retryer<Boolean> retryer = RetryerBuilder.<Boolean>newBuilder()    .retryIfException()    .retryIfResult(Predicates.equalTo(false))    .withAttemptTimeLimiter(AttemptTimeLimiters.fixedTimeLimit(1, TimeUnit.SECONDS))    .withStopStrategy(StopStrategies.stopAfterAttempt(5))    .build();//Retryer調用                retryer.call(() -> true);復制代碼
  • spring也有對應的重試機制,相關文章可以看看重試框架Guava-Retry和spring-Retry


    作者:潛行前行
    鏈接:https://juejin.cn/post/6974202216768864264
    來源:掘金
    著作權歸作者所有。商業(yè)轉載請聯系作者獲得授權,非商業(yè)轉載請注明出處。

  •  
    (文/啊丟)
    免責聲明
    本文僅代表作發(fā)布者:啊丟個人觀點,本站未對其內容進行核實,請讀者僅做參考,如若文中涉及有違公德、觸犯法律的內容,一經發(fā)現,立即刪除,需自行承擔相應責任。涉及到版權或其他問題,請及時聯系我們刪除處理郵件:weilaitui@qq.com。
     

    Copyright ? 2016 - 2025 - 企資網 48903.COM All Rights Reserved 粵公網安備 44030702000589號

    粵ICP備16078936號

    微信

    關注
    微信

    微信二維碼

    WAP二維碼

    客服

    聯系
    客服

    聯系客服:

    在線QQ: 303377504

    客服電話: 020-82301567

    E_mail郵箱: weilaitui@qq.com

    微信公眾號: weishitui

    客服001 客服002 客服003

    工作時間:

    周一至周五: 09:00 - 18:00

    反饋

    用戶
    反饋

    欧美亚洲自拍偷拍_日本一区视频在线观看_国产二区在线播放_亚洲男人第一天堂

          9000px;">

                成人美女在线视频| 日韩一区二区影院| 91久久香蕉国产日韩欧美9色| 成人一区二区在线观看| 欧亚洲嫩模精品一区三区| 欧美日产国产精品| 欧美精品一区二区三区一线天视频| 中文字幕第一区综合| 亚洲成人自拍偷拍| 国产精品1024| 欧美日韩你懂的| 欧美激情在线观看视频免费| 五月婷婷综合激情| 91在线观看一区二区| 日韩午夜精品电影| 91在线无精精品入口| 成人91在线观看| 日韩欧美国产精品| 亚洲电影在线免费观看| av电影在线不卡| 久久久精品日韩欧美| 日韩精彩视频在线观看| 91国模大尺度私拍在线视频| 中文一区在线播放| 国产一区二区三区国产| 欧美日韩大陆一区二区| 亚洲乱码国产乱码精品精小说| 国模一区二区三区白浆| 欧美一区欧美二区| 欧美午夜精品电影| 综合av第一页| av男人天堂一区| 国产日韩在线不卡| 麻豆视频一区二区| 日韩午夜激情视频| 麻豆专区一区二区三区四区五区| 欧美另类一区二区三区| 午夜日韩在线电影| 欧美精品自拍偷拍| 日本网站在线观看一区二区三区| 欧美亚洲综合另类| 亚洲视频免费观看| 亚洲国产视频a| 欧美三区免费完整视频在线观看| 亚洲美女免费在线| 91小视频在线免费看| 中文字幕一区二区三区色视频 | 欧美日本视频在线| 一区二区三区鲁丝不卡| 一本到一区二区三区| 亚洲免费高清视频在线| zzijzzij亚洲日本少妇熟睡| 色婷婷激情综合| 一区二区三区中文字幕| 在线看一区二区| 亚洲成av人片在线| 日韩免费视频一区| 福利电影一区二区三区| 一色屋精品亚洲香蕉网站| 一本久久综合亚洲鲁鲁五月天| 一区二区在线电影| 欧美日韩国产美| 日韩电影免费在线| 精品国内片67194| 国产成人亚洲综合a∨婷婷| 国产日本一区二区| 在线视频你懂得一区二区三区| 午夜精彩视频在线观看不卡| 精品乱人伦小说| 不卡的看片网站| 91福利视频网站| 亚洲激情av在线| 欧美一区二区三区小说| 国产精品白丝av| 亚洲免费在线电影| 91精品国产91热久久久做人人| 精品一区二区三区免费| 亚洲人精品午夜| 欧美一区二区三区在线看| 国产精品99久久久久| 亚洲综合精品自拍| 日韩一区二区免费高清| 不卡视频在线看| 香港成人在线视频| 亚洲第一搞黄网站| 男人的天堂久久精品| 久久精品一区二区三区不卡牛牛 | 国产精品久线在线观看| 欧美视频你懂的| 国产精品一区二区久久精品爱涩| 一区二区欧美精品| 国产片一区二区| 欧美高清hd18日本| 99r精品视频| 精品一区二区在线免费观看| 亚洲精品成人a在线观看| 精品久久久久av影院| 色婷婷av一区二区三区gif| 一区二区三区久久| 在线观看欧美精品| 久久99国产精品免费网站| 自拍视频在线观看一区二区| 日韩三级视频在线观看| 色伊人久久综合中文字幕| 国产精品一区二区黑丝| 免费高清成人在线| 亚洲午夜电影在线观看| 国产精品福利一区二区| 久久综合狠狠综合久久激情| 欧美日韩视频在线第一区| 波波电影院一区二区三区| 狠狠久久亚洲欧美| 日韩国产一二三区| 亚洲综合激情网| 亚洲欧洲精品一区二区三区不卡 | 国产精品1区2区| 青椒成人免费视频| 亚洲国产美国国产综合一区二区| 欧美国产丝袜视频| 26uuu亚洲综合色| 欧美mv日韩mv| 欧美一级二级三级乱码| 欧美在线制服丝袜| 在线视频欧美精品| 欧美性受xxxx黑人xyx| av不卡在线观看| 色综合天天性综合| 日本久久一区二区三区| 一本色道**综合亚洲精品蜜桃冫 | 99免费精品视频| 国v精品久久久网| 成人亚洲精品久久久久软件| 国产91色综合久久免费分享| 国产成人综合精品三级| 国产成人小视频| 成人福利视频网站| 91麻豆文化传媒在线观看| 色菇凉天天综合网| 欧美日韩电影在线播放| 欧美一级片在线观看| 精品精品欲导航| xnxx国产精品| 欧美国产97人人爽人人喊| 中文字幕乱码日本亚洲一区二区 | 欧美日韩精品久久久| 欧美日韩中文字幕一区| 欧美欧美午夜aⅴ在线观看| 日韩欧美一二三四区| 久久综合狠狠综合久久激情 | 91网站在线播放| 色94色欧美sute亚洲线路一久| 欧美在线不卡视频| 欧美另类z0zxhd电影| 欧美一级欧美三级在线观看| 精品国产123| 日韩毛片高清在线播放| 天天综合天天做天天综合| 美女一区二区久久| 国产一区二区三区黄视频| 欧美丝袜丝nylons| 亚洲黄色免费网站| 青青草97国产精品免费观看无弹窗版| 久久成人免费电影| 成人午夜在线播放| 欧美在线不卡一区| 国产欧美一区视频| 亚洲不卡av一区二区三区| 日本欧美加勒比视频| 岛国一区二区在线观看| 欧美性受xxxx黑人xyx性爽| 2023国产精品| 一区二区三区中文免费| 国产精品1区二区.| 91精品一区二区三区在线观看| 精品电影一区二区三区| 亚洲美女偷拍久久| 国产蜜臀av在线一区二区三区| 亚洲久本草在线中文字幕| 欧美aⅴ一区二区三区视频| 99精品久久久久久| 日韩美女视频一区二区在线观看| 国产精品视频线看| 石原莉奈一区二区三区在线观看| 高清beeg欧美| 日韩欧美激情一区| 亚洲一区二区精品久久av| 国产精品91一区二区| 日韩你懂的在线观看| 夜夜夜精品看看| 波多野结衣一区二区三区| 日韩欧美国产午夜精品| 亚洲一区二区三区小说| 国产69精品久久99不卡| 日韩精品中文字幕一区| 亚洲午夜影视影院在线观看| 成人免费毛片片v| 久久久无码精品亚洲日韩按摩| 午夜精品久久久久久久99樱桃| 一本色道久久综合狠狠躁的推荐| 日本一区二区免费在线观看视频|