自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

前5個(gè)基于Redis的Java對象

存儲 Redis
Redis具有很多值得推薦的功能,包括速度,可伸縮性和可用性。但是,有一個(gè)問題是Redis不包括對Java之類的編程語言的內(nèi)置支持。相反,用戶需要為Redis安裝第三方Java客戶端,例如Redisson。

 Redis具有很多值得推薦的功能,包括速度,可伸縮性和可用性。但是,有一個(gè)問題是Redis不包括對Java之類的編程語言的內(nèi)置支持。相反,用戶需要為Redis安裝第三方Java客戶端,例如Redisson。

[[328825]]

Redisson是Redis Java客戶端,其中包含許多熟悉的Java對象,接口和集合,這使Java開發(fā)人員比以往任何時(shí)候都更容易地開始使用Redis。下面,我們將討論Radisson用戶所依賴的5個(gè)基于Redis的優(yōu)秀Java對象。

1.Map

Java中的Map接口用于將鍵映射到值的對象。

Redisson使用RMap接口在Redis中實(shí)現(xiàn)Map 。旋轉(zhuǎn)地圖實(shí)現(xiàn)了所有的Redis的熟悉地圖的方法:containsKey(),containsValue(),get(),isEmpty(),keySet(),put(),putIfAbsent(),remove(),replace(),values(),等等。

以下是有關(guān)如何在Redisson中使用RMap接口的快速示例:

 

  1. RMap<String, SomeObject> map = redisson.getMap("anyMap"); 
  2. SmeObject prevObject = map.put("123", new SomeObject()); 
  3. SomeObject currentObject = map.putIfAbsent("323", new SomeObject()); 
  4. SomeObject obj = map.remove("123"); 

RMap接口包括對Async,Reactive和RxJava2的支持。此外,RMap還具有本地緩存​​和數(shù)據(jù)分區(qū)等功能,因此可以極大地加快讀取操作并提高可伸縮性。

 

2.Set

Java中的Set接口用于無重復(fù)值的元素的無序集合。

Redisson器具設(shè)置在Redis的與RSET接口。RSET實(shí)現(xiàn)所有的Redis的熟悉的設(shè)置方法:add(),addAll(),clear(),contains(),containsAll(),equals(),isEmpty(),remove(),removeAll(),size(),等等。

以下是有關(guān)如何在Redisson中使用RSet接口的快速示例:

 

  1. RSet<SomeObject> set = redisson.getSet("anySet"); 
  2. set.add(new SomeObject()); 
  3. set.remove(new SomeObject()); 

與RMap一樣,RSet也支持?jǐn)?shù)據(jù)分區(qū),以提高性能并加快讀/寫操作。另外,用戶可以為RMap中的元素定義驅(qū)逐策略(即每個(gè)條目的生存時(shí)間)。

3.holder

Java中的Holder類用于存儲指定類型的值,同時(shí)允許對該值進(jìn)行副作用修改(例如,為了在Java中實(shí)現(xiàn)按引用調(diào)用)。

Redisson通過RBucket接口在Redis中實(shí)現(xiàn)了Holder類,該接口可以容納任何類型的對象。RBucket工具方法,如compareAndSet(),get(),getAndDelete(),getAndSet(),set(),size(),trySet(),等等。對象的最大大小為512兆字節(jié)。

以下是有關(guān)如何在Redisson中使用RBucket接口的快速示例:

 

  1. RBucket<AnyObject> bucket = redisson.getBucket("anyObject"); 
  2. bucket.set(new AnyObject(1)); 
  3. AnyObject obj = bucket.get(); 
  4. bucket.trySet(new AnyObject(3)); 
  5. bucket.compareAndSet(new AnyObject(4), new AnyObject(5)); 
  6. bucket.getAndSet(new AnyObject(6)); 

RBucket接口包括對Async,Reactive和RxJava2的支持。

 

4.Lock

Java中的Lock類用于“鎖定”對共享資源的訪問,以同步多個(gè)線程。鎖是多線程和分布式編程的關(guān)鍵部分,這就是為什么鎖在Redisson用戶中也很受歡迎的原因。

Redisson通過RLock接口在Redis中實(shí)現(xiàn)Lock類。RLOCK實(shí)現(xiàn)所有的Redis的熟悉鎖方法:lock(),lockInterruptibly(),tryLock(),unlock(),等等。

以下是有關(guān)如何在Redisson中使用RLock接口的快速示例:

 

  1. RLock lock = redisson.getLock("myLock"); 
  2. //傳統(tǒng)的鎖定方法 
  3. lock.lock(); 
  4. // 或獲取鎖定,并在10秒后自動將其解鎖 
  5. lock.lock(10, TimeUnit.SECONDS); 
  6. //或等待鎖獲取長達(dá)100秒  
  7. //并在10秒后自動將其解鎖 
  8. boolean res = lock.tryLock(100, 10, TimeUnit.SECONDS); 
  9. if (res) { 
  10.    try { 
  11.      ... 
  12.    } finally { 
  13.        lock.unlock(); 
  14.    } 

RLock接口包括對Async,Reactive和RxJava2的支持。Redisson還實(shí)現(xiàn)了各種類型的鎖,例如公平鎖,MultiLock,Redlock和ReadWriteLocks。

 

5.ExecutorService

Java中的ExecutorService接口用于異步執(zhí)行Runnable和Callable對象。

Redisson實(shí)現(xiàn)了Redis的的ExecutorService的接口與RExecutorService接口。RExecutorService實(shí)現(xiàn)所有的Redis的熟悉的ExecutorService方法:invokeAll(),invokeAny(),isShutdown(),isTerminated(),shutdown(),shutdownNow(),submit(),等等。

以下是有關(guān)如何在Redisson中使用RExecutorService接口的快速示例:

 

  1. RExecutorService executorService = redisson.getExecutorService("myExecutor", options); 
  2. executorService.submit(new RunnableTask(123)); 
  3. RExecutorService executorService = redisson.getExecutorService("myExecutor", options); 
  4. Future<Long> future = executorService.submit(new CallableTask()); 
  5. Long result = future.get(); 

RExecutorService接口包括對Runnable和Callable對象,Lambda任務(wù)以及Spring Bean任務(wù)的支持。

結(jié)論

Redisson內(nèi)置了對Redis中許多最常見Java對象的內(nèi)置支持,包括Map,Set,Objectholder,Lock和ExecutorService。

責(zé)任編輯:華軒 來源: 今日頭條
相關(guān)推薦

2019-07-15 14:49:16

網(wǎng)絡(luò)安全云計(jì)算軟件

2009-12-09 09:40:31

Linux云計(jì)算

2018-03-07 13:30:09

數(shù)據(jù)庫Redis

2011-07-27 09:30:21

HTML 5

2012-02-02 10:27:23

Windows8 Be問題

2011-12-05 10:38:37

Java面試

2018-02-09 08:09:24

Redis軟件用法

2018-11-19 05:34:31

云計(jì)算云安全IT

2016-01-20 10:11:56

華麗CanvasHTML5

2010-08-04 13:43:59

Flex項(xiàng)目

2015-10-08 09:28:47

JavaDocker鏡像

2017-02-28 20:34:08

Linux移動應(yīng)用程序員

2021-04-26 08:36:56

Javascript輪播庫開發(fā)

2020-08-23 09:12:52

JavaJava IDE框架

2012-04-05 13:19:06

WEBHTML5

2019-02-18 13:36:03

Redis數(shù)據(jù)庫面試

2020-11-24 09:45:57

JavaScript開發(fā)框架

2009-07-14 09:06:08

Java對象類型轉(zhuǎn)換

2010-07-19 11:28:14

SQL Server

2012-04-09 09:29:02

Java
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號