Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
weixin_57962205
redisson
提交
e234d6ca
R
redisson
项目概览
weixin_57962205
/
redisson
与 Fork 源项目一致
从无法访问的项目Fork
通知
10
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
redisson
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
e234d6ca
编写于
1月 18, 2018
作者:
N
Nikita
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
refactoring
上级
6bcd474c
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
20 addition
and
26 deletion
+20
-26
redisson/src/main/java/org/redisson/RedissonBaseAdder.java
redisson/src/main/java/org/redisson/RedissonBaseAdder.java
+16
-22
redisson/src/main/java/org/redisson/RedissonDoubleAdder.java
redisson/src/main/java/org/redisson/RedissonDoubleAdder.java
+2
-2
redisson/src/main/java/org/redisson/RedissonLongAdder.java
redisson/src/main/java/org/redisson/RedissonLongAdder.java
+2
-2
未找到文件。
redisson/src/main/java/org/redisson/RedissonBaseAdder.java
浏览文件 @
e234d6ca
...
...
@@ -15,17 +15,13 @@
*/
package
org.redisson
;
import
java.util.Arrays
;
import
org.redisson.api.RFuture
;
import
org.redisson.api.RSemaphore
;
import
org.redisson.api.RTopic
;
import
org.redisson.api.RedissonClient
;
import
org.redisson.api.listener.MessageListener
;
import
org.redisson.client.codec.LongCodec
;
import
org.redisson.client.protocol.RedisCommands
;
import
org.redisson.command.CommandAsyncExecutor
;
import
org.redisson.misc.LongAdder
;
import
org.redisson.misc.RPromise
;
import
org.redisson.misc.RedissonPromise
;
import
org.slf4j.Logger
;
...
...
@@ -109,20 +105,17 @@ public abstract class RedissonBaseAdder<T extends Number> extends RedissonExpira
public
RFuture
<
T
>
sumAsync
()
{
final
RPromise
<
T
>
result
=
new
RedissonPromise
<
T
>();
RFuture
<
Integer
>
future
=
commandExecutor
.
evalWriteAsync
(
getName
(),
codec
,
RedisCommands
.
EVAL_INTEGER
,
"redis.call('del', KEYS[1]); "
+
"return redis.call('publish', KEYS[2], ARGV[1]); "
,
Arrays
.<
Object
>
asList
(
getName
(),
topic
.
getChannelNames
().
get
(
0
)),
SUM_MSG
);
future
.
addListener
(
new
FutureListener
<
Integer
>()
{
RFuture
<
Long
>
future
=
topic
.
publishAsync
(
SUM_MSG
);
future
.
addListener
(
new
FutureListener
<
Long
>()
{
@Override
public
void
operationComplete
(
Future
<
Integer
>
future
)
throws
Exception
{
public
void
operationComplete
(
Future
<
Long
>
future
)
throws
Exception
{
if
(!
future
.
isSuccess
())
{
result
.
tryFailure
(
future
.
cause
());
return
;
}
semaphore
.
acquireAsync
(
future
.
getNow
()).
addListener
(
new
FutureListener
<
Void
>()
{
semaphore
.
acquireAsync
(
future
.
getNow
()
.
intValue
()
).
addListener
(
new
FutureListener
<
Void
>()
{
@Override
public
void
operationComplete
(
Future
<
Void
>
future
)
throws
Exception
{
if
(!
future
.
isSuccess
())
{
...
...
@@ -130,7 +123,7 @@ public abstract class RedissonBaseAdder<T extends Number> extends RedissonExpira
return
;
}
RFuture
<
T
>
valueFuture
=
getAsync
();
RFuture
<
T
>
valueFuture
=
getA
ndDeleteA
sync
();
valueFuture
.
addListener
(
new
FutureListener
<
T
>()
{
@Override
public
void
operationComplete
(
Future
<
T
>
future
)
throws
Exception
{
...
...
@@ -153,21 +146,22 @@ public abstract class RedissonBaseAdder<T extends Number> extends RedissonExpira
public
RFuture
<
Void
>
resetAsync
()
{
final
RPromise
<
Void
>
result
=
new
RedissonPromise
<
Void
>();
RFuture
<
Integer
>
future
=
commandExecutor
.
evalWriteAsync
(
getName
(),
codec
,
RedisCommands
.
EVAL_INTEGER
,
"redis.call('del', KEYS[1]); "
+
"return redis.call('publish', KEYS[2], ARGV[1]); "
,
Arrays
.<
Object
>
asList
(
getName
(),
topic
.
getChannelNames
().
get
(
0
)),
CLEAR_MSG
);
future
.
addListener
(
new
FutureListener
<
Integer
>()
{
RFuture
<
Long
>
future
=
topic
.
publishAsync
(
CLEAR_MSG
);
future
.
addListener
(
new
FutureListener
<
Long
>()
{
@Override
public
void
operationComplete
(
Future
<
Integer
>
future
)
throws
Exception
{
public
void
operationComplete
(
Future
<
Long
>
future
)
throws
Exception
{
if
(!
future
.
isSuccess
())
{
result
.
tryFailure
(
future
.
cause
());
return
;
}
semaphore
.
acquireAsync
(
future
.
getNow
()).
addListener
(
new
FutureListener
<
Void
>()
{
int
value
=
0
;
if
(
future
.
getNow
()
!=
null
)
{
value
=
future
.
getNow
().
intValue
();
}
semaphore
.
acquireAsync
(
value
).
addListener
(
new
FutureListener
<
Void
>()
{
@Override
public
void
operationComplete
(
Future
<
Void
>
future
)
throws
Exception
{
if
(!
future
.
isSuccess
())
{
...
...
@@ -190,6 +184,6 @@ public abstract class RedissonBaseAdder<T extends Number> extends RedissonExpira
protected
abstract
RFuture
<
T
>
addAndGetAsync
();
protected
abstract
RFuture
<
T
>
getAsync
();
protected
abstract
RFuture
<
T
>
getA
ndDeleteA
sync
();
}
redisson/src/main/java/org/redisson/RedissonDoubleAdder.java
浏览文件 @
e234d6ca
...
...
@@ -50,8 +50,8 @@ public class RedissonDoubleAdder extends RedissonBaseAdder<Double> implements RD
}
@Override
protected
RFuture
<
Double
>
getAsync
()
{
return
atomicDouble
.
getAsync
();
protected
RFuture
<
Double
>
getA
ndDeleteA
sync
()
{
return
atomicDouble
.
getA
ndDeleteA
sync
();
}
@Override
...
...
redisson/src/main/java/org/redisson/RedissonLongAdder.java
浏览文件 @
e234d6ca
...
...
@@ -49,8 +49,8 @@ public class RedissonLongAdder extends RedissonBaseAdder<Long> implements RLongA
}
@Override
protected
RFuture
<
Long
>
getAsync
()
{
return
atomicLong
.
getAsync
();
protected
RFuture
<
Long
>
getA
ndDeleteA
sync
()
{
return
atomicLong
.
getA
ndDeleteA
sync
();
}
@Override
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录