您的位置:首页 > 编程语言 > Java开发

JAVA原子性操作

2016-06-02 00:00 309 查看
摘要: JAVA原子性操作

java 原子性操作

Java中的原子操作包括:
1)除long和double之外的基本类型的赋值操作

2)所有引用reference的赋值操作

3)java.concurrent.Atomic.* 包中所有类的一切操作

count++不是原子操作,是3个原子操作组合

1.读取主存中的count值,赋值给一个局部成员变量tmp
2.tmp+1
3.将tmp赋值给count

要使用AtomicInteger.getAndIncrement()才可以避免并发问题

原子性操作与加锁实例:

package com.yy.ent.antiad.common.util;
import java.util.concurrent.atomic.AtomicInteger;
/**
* 原子性自增与加锁方式对比
* @author huangyucai1@yy.com
* @since 2016-6-2
*/
public class AtomicTest {
private int value;

public AtomicTest(int value){
this.value = value;
}

public synchronized int increase(){
return value++;
}

public int getValue(){
return value;
}

public static void main(String args[]){
long start = System.currentTimeMillis();

AtomicTest test = new AtomicTest(0);
for( int i=0;i< 100000000;i++){
test.increase();
}
long end = System.currentTimeMillis();
System.out.println(test.getValue()+" times increase synchronize time cost:"+(end -start)+" ms");

start = System.currentTimeMillis();
AtomicInteger atomic = new AtomicInteger(0);

for(int i=0;i< 100000000;i++){
atomic.incrementAndGet();
}
end = System.currentTimeMillis();
System.out.println(atomic.intValue() +" times increase atomic time cost:"+(end - start)+" ms" );
}

}

运行结果

100000000 times increase synchronize time cost:2857 ms

100000000 times increase atomic time cost:1033 ms
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: