- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章Java中对AtomicInteger和int值在多线程下递增操作的测试由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
Java针对多线程下的数值安全计数器设计了一些类,这些类叫做原子类,其中一部分如下
1
2
3
4
|
java.util.concurrent.atomic.AtomicBoolean;
java.util.concurrent.atomic.AtomicInteger;
java.util.concurrent.atomic.AtomicLong;
java.util.concurrent.atomic.AtomicReference;
|
下面是一个对比 AtomicInteger 与 普通 int 值在多线程下的递增测试,使用的是 junit4,
完整代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
|
package
test.java;
import
java.util.concurrent.CountDownLatch;
import
java.util.concurrent.atomic.AtomicInteger;
import
org.junit.Assert;
import
org.junit.Before;
import
org.junit.Test;
/**
* 测试AtomicInteger与普通int值在多线程下的递增操作
*/
public
class
TestAtomic {
// 原子Integer递增对象
public
static
AtomicInteger counter_integer;
// = new AtomicInteger(0);
// 一个int类型的变量
public
static
int
count_int =
0
;
@Before
public
void
setUp() {
// 所有测试开始之前执行初始设置工作
counter_integer =
new
AtomicInteger(
0
);
}
@Test
public
void
testAtomic()
throws
InterruptedException {
// 创建的线程数量
int
threadCount =
100
;
// 其他附属线程内部循环多少次
int
loopCount =
10000600
;
// 控制附属线程的辅助对象;(其他await的线程先等着主线程喊开始)
CountDownLatch latch_1 =
new
CountDownLatch(
1
);
// 控制主线程的辅助对象;(主线程等着所有附属线程都运行完毕再继续)
CountDownLatch latch_n =
new
CountDownLatch(threadCount);
// 创建并启动其他附属线程
for
(
int
i =
0
; i < threadCount; i++) {
Thread thread =
new
AtomicIntegerThread(latch_1, latch_n, loopCount);
thread.start();
}
long
startNano = System.nanoTime();
// 让其他等待的线程统一开始
latch_1.countDown();
// 等待其他线程执行完
latch_n.await();
//
long
endNano = System.nanoTime();
int
sum = counter_integer.get();
//
Assert.assertEquals(
"sum 不等于 threadCount * loopCount,测试失败"
,
sum, threadCount * loopCount);
System.out.println(
"--------testAtomic(); 预期两者相等------------"
);
System.out.println(
"耗时: "
+ ((endNano - startNano) / (
1000
*
1000
)) +
"ms"
);
System.out.println(
"threadCount = "
+ (threadCount) +
";"
);
System.out.println(
"loopCount = "
+ (loopCount) +
";"
);
System.out.println(
"sum = "
+ (sum) +
";"
);
}
@Test
public
void
testIntAdd()
throws
InterruptedException {
// 创建的线程数量
int
threadCount =
100
;
// 其他附属线程内部循环多少次
int
loopCount =
10000600
;
// 控制附属线程的辅助对象;(其他await的线程先等着主线程喊开始)
CountDownLatch latch_1 =
new
CountDownLatch(
1
);
// 控制主线程的辅助对象;(主线程等着所有附属线程都运行完毕再继续)
CountDownLatch latch_n =
new
CountDownLatch(threadCount);
// 创建并启动其他附属线程
for
(
int
i =
0
; i < threadCount; i++) {
Thread thread =
new
IntegerThread(latch_1, latch_n, loopCount);
thread.start();
}
long
startNano = System.nanoTime();
// 让其他等待的线程统一开始
latch_1.countDown();
// 等待其他线程执行完
latch_n.await();
//
long
endNano = System.nanoTime();
int
sum = count_int;
//
Assert.assertNotEquals(
"sum 等于 threadCount * loopCount,testIntAdd()测试失败"
,
sum, threadCount * loopCount);
System.out.println(
"-------testIntAdd(); 预期两者不相等---------"
);
System.out.println(
"耗时: "
+ ((endNano - startNano) / (
1000
*
1000
))+
"ms"
);
System.out.println(
"threadCount = "
+ (threadCount) +
";"
);
System.out.println(
"loopCount = "
+ (loopCount) +
";"
);
System.out.println(
"sum = "
+ (sum) +
";"
);
}
// 线程
class
AtomicIntegerThread
extends
Thread {
private
CountDownLatch latch =
null
;
private
CountDownLatch latchdown =
null
;
private
int
loopCount;
public
AtomicIntegerThread(CountDownLatch latch,
CountDownLatch latchdown,
int
loopCount) {
this
.latch = latch;
this
.latchdown = latchdown;
this
.loopCount = loopCount;
}
@Override
public
void
run() {
// 等待信号同步
try
{
this
.latch.await();
}
catch
(InterruptedException e) {
e.printStackTrace();
}
//
for
(
int
i =
0
; i < loopCount; i++) {
counter_integer.getAndIncrement();
}
// 通知递减1次
latchdown.countDown();
}
}
// 线程
class
IntegerThread
extends
Thread {
private
CountDownLatch latch =
null
;
private
CountDownLatch latchdown =
null
;
private
int
loopCount;
public
IntegerThread(CountDownLatch latch,
CountDownLatch latchdown,
int
loopCount) {
this
.latch = latch;
this
.latchdown = latchdown;
this
.loopCount = loopCount;
}
@Override
public
void
run() {
// 等待信号同步
try
{
this
.latch.await();
}
catch
(InterruptedException e) {
e.printStackTrace();
}
//
for
(
int
i =
0
; i < loopCount; i++) {
count_int++;
}
// 通知递减1次
latchdown.countDown();
}
}
}
|
普通PC机上的执行结果类似如下
1
2
3
4
5
6
7
8
9
10
|
--------------testAtomic(); 预期两者相等-------------------
耗时: 85366ms
threadCount = 100;
loopCount = 10000600;
sum = 1000060000;
--------------testIntAdd(); 预期两者不相等-------------------
耗时: 1406ms
threadCount = 100;
loopCount = 10000600;
sum = 119428988;
|
。
从中可以看出, AtomicInteger操作 与 int操作的效率大致相差在50-80倍上下,当然,int很不消耗时间,这个对比只是提供一个参照.
如果确定是单线程执行,那应该使用 int; 而int在多线程下的操作执行的效率还是蛮高的, 10亿次只花了1.5秒钟; 。
(假设CPU是 2GHZ,双核4线程,理论最大8GHZ,则每秒理论上有80亿个时钟周期.
10亿次Java的int增加消耗了1.5秒,即 120亿次运算, 算下来每次循环消耗CPU周期 12个,
个人觉得效率不错, C 语言也应该需要4个以上的时钟周期(判断,执行内部代码,自增判断,跳转) 。
前提是: JVM和CPU没有进行激进优化. 。
) 。
而 AtomicInteger 效率其实也不低,10亿次消耗了80秒, 那100万次大约也就是千分之一,80毫秒的样子. 。
最后此篇关于Java中对AtomicInteger和int值在多线程下递增操作的测试的文章就讲到这里了,如果你想了解更多关于Java中对AtomicInteger和int值在多线程下递增操作的测试的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我获得了一些源代码示例,我想测试一些功能。不幸的是,我在执行程序时遇到问题: 11:41:31 [linqus@ottsrvafq1 example]$ javac -g test/test.jav
我想测试ggplot生成的两个图是否相同。一种选择是在绘图对象上使用all.equal,但我宁愿进行更艰巨的测试以确保它们相同,这似乎是identical()为我提供的东西。 但是,当我测试使用相同d
我确实使用 JUnit5 执行我的 Maven 测试,其中所有测试类都有 @ExtendWith({ProcessExtension.class}) 注释。如果是这种情况,此扩展必须根据特殊逻辑使测试
在开始使用 Node.js 开发有用的东西之前,您的流程是什么?您是否在 VowJS、Expresso 上创建测试?你使用 Selenium 测试吗?什么时候? 我有兴趣获得一个很好的工作流程来开发我
这个问题已经有答案了: What is a NullPointerException, and how do I fix it? (12 个回答) 已关闭 3 年前。 基于示例here ,我尝试为我的
我正在考虑测试一些 Vue.js 组件,作为 Laravel 应用程序的一部分。所以,我有一个在 Blade 模板中使用并生成 GET 的组件。在 mounted 期间请求生命周期钩子(Hook)。假
考虑以下程序: #include struct Test { int a; }; int main() { Test t=Test(); std::cout<
我目前的立场是:如果我使用 web 测试(在我的例子中可能是通过 VS.NET'08 测试工具和 WatiN)以及代码覆盖率和广泛的数据来彻底测试我的 ASP.NET 应用程序,我应该不需要编写单独的
我正在使用 C#、.NET 4.7 我有 3 个字符串,即。 [test.1, test.10, test.2] 我需要对它们进行排序以获得: test.1 test.2 test.10 我可能会得到
我有一个 ID 为“rv_list”的 RecyclerView。单击任何 RecyclerView 项目时,每个项目内都有一个可见的 id 为“star”的 View 。 我想用 expresso
我正在使用 Jest 和模拟器测试 Firebase 函数,尽管这些测试可能来自竞争条件。所谓 flakey,我的意思是有时它们会通过,有时不会,即使在同一台机器上也是如此。 测试和函数是用 Type
我在测试我与 typeahead.js ( https://github.com/angular-ui/bootstrap/blob/master/src/typeahead/typeahead.js
我正在尝试使用 Teamcity 自动运行测试,但似乎当代理编译项目时,它没有正确完成,因为当我运行运行测试之类的命令时,我收到以下错误: fatal error: 'Pushwoosh/PushNo
这是我第一次玩 cucumber ,还创建了一个测试和 API 的套件。我的问题是在测试 API 时是否需要运行它? 例如我脑子里有这个, 启动 express 服务器作为后台任务 然后当它启动时(我
我有我的主要应用程序项目,然后是我的测试的第二个项目。将所有类型的测试存储在该测试项目中是一种好的做法,还是应该将一些测试驻留在主应用程序项目中? 我应该在我的主项目中保留 POJO JUnit(测试
我正在努力弄清楚如何实现这个计数。模型是用户、测试、等级 用户 has_many 测试,测试 has_many 成绩。 每个等级都有一个计算分数(strong_pass、pass、fail、stron
我正在尝试测试一些涉及 OkHttp3 的下载代码,但不幸失败了。目标:测试 下载图像文件并验证其是否有效。平台:安卓。此代码可在生产环境中运行,但测试代码没有任何意义。 产品代码 class Fil
当我想为 iOS 运行 UI 测试时,我收到以下消息: SetUp : System.Exception : Unable to determine simulator version for X 堆
我正在使用 Firebase Remote Config 在 iOS 上设置 A/B 测试。 一切都已设置完毕,我正在 iOS 应用程序中读取服务器端默认值。 但是在多个模拟器上尝试,它们都读取了默认
[已编辑]:我已经用 promise 方式更改了我的代码。 我正在写 React with this starter 由 facebook 创建,我是测试方面的新手。 现在我有一个关于图像的组件,它有
我是一名优秀的程序员,十分优秀!