count++不是原子性操作测试
来源:互联网 发布:飞升符箓升级数据 编辑:程序博客网 时间:2024/05/22 11:47
package com.ssy.base;
import java.util.concurrent.BrokenBarrierException;
import java.util.concurrent.CyclicBarrier;
public class CountJIAJIATest {
public static void main(String[] args) throws InterruptedException, BrokenBarrierException {
for(int i=0;i<1000;i++){// 执行1000次,其中会有几次不符合预期
new CountTest().run();
}
}
}
/**
* @Author saintshi
* @Date 2016年2月1日 下午4:46:47
* 注:其中CyclicBarrier的作用是等到所有线程都执行完成之后再执行下一步
* 在这里的作用是,主线程等待子线程执行完在执行下一步(count.get())
*/
class CountTest{
final Count count = new Count();
final int _num_thread = 100;
final int _num_count = 1000;
final CyclicBarrier cb = new CyclicBarrier(_num_thread+1);
public void run(){
try {
for(int i=0;i<_num_thread;i++){
Thread t = new Thread(){
public void run() {
try {
for(int j=0;j<_num_count;j++){
count.add();
}
cb.await();
} catch (Exception e) {
e.printStackTrace();
}
};
};
t.setDaemon(false);
t.start();
}
cb.await();
int result = count.get();
if(result!=_num_thread*_num_count){
System.out.println(result);// 如果不符合预期(count++原子执行)就会打印
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
class Count{
private int count;
public void add(){
// synchronized (this) {// 如果不加上会出现与不符合预期的结果
count++;
// }
}
public int get(){
return count;
}
}
import java.util.concurrent.BrokenBarrierException;
import java.util.concurrent.CyclicBarrier;
public class CountJIAJIATest {
public static void main(String[] args) throws InterruptedException, BrokenBarrierException {
for(int i=0;i<1000;i++){// 执行1000次,其中会有几次不符合预期
new CountTest().run();
}
}
}
/**
* @Author saintshi
* @Date 2016年2月1日 下午4:46:47
* 注:其中CyclicBarrier的作用是等到所有线程都执行完成之后再执行下一步
* 在这里的作用是,主线程等待子线程执行完在执行下一步(count.get())
*/
class CountTest{
final Count count = new Count();
final int _num_thread = 100;
final int _num_count = 1000;
final CyclicBarrier cb = new CyclicBarrier(_num_thread+1);
public void run(){
try {
for(int i=0;i<_num_thread;i++){
Thread t = new Thread(){
public void run() {
try {
for(int j=0;j<_num_count;j++){
count.add();
}
cb.await();
} catch (Exception e) {
e.printStackTrace();
}
};
};
t.setDaemon(false);
t.start();
}
cb.await();
int result = count.get();
if(result!=_num_thread*_num_count){
System.out.println(result);// 如果不符合预期(count++原子执行)就会打印
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
class Count{
private int count;
public void add(){
// synchronized (this) {// 如果不加上会出现与不符合预期的结果
count++;
// }
}
public int get(){
return count;
}
}
0 0
- count++不是原子性操作测试
- Count++不是线程安全的 不是原子性的
- i++不是原子操作
- i++ 不是原子操作
- java中的自增过程不是原子性操作
- 验证java 递增不是原子操作
- java 递增不是原子操作-并发
- 原子性与原子操作
- Voliate为什么不是原子性
- 32位JVM对long类型的赋值不是原子性操作
- 证明32位java对long和double的写操作不是原子性的
- ++count具不具有原子性
- 原子性操作atomic_t
- 原子性操作atomic_t
- 原子性操作atomic_t
- 原子性操作atomic_t
- 原子性操作atomic_t
- 非原子性操作
- 36个Android开发常用代码片段
- .sql文件中的注释
- cookie的操作
- 判断目标是否在角色正前方一个扇形区域内,一般战斗系统中用作伤害处理
- day05 _未完待续
- count++不是原子性操作测试
- 五分钟初识Hadoop
- 1020. Tree Traversals (25)
- java.lang.IllegalArgumentException: Document base D:\apache-tomcat-6.0.20\webapps\XXX错误
- Java动态代理的实现机制
- left join on and 与 left join on where的区别
- bug记录:Json Parsing Error : JSON.parse: bad control character in string literal
- 【java基础】Minor GC、Major GC和Full GC之间的区别
- OracleSQLDeveloper使用教程