JAVA原子性操做

java 原子性操做java

Java中的原子操做包括: 1)除long和double以外的基本類型的賦值操做併發

2)全部引用reference的賦值操做this

3)java.concurrent.Atomic.* 包中全部類的一切操做atom

count++不是原子操做,是3個原子操做組合code

1.讀取主存中的count值,賦值給一個局部成員變量tmp 2.tmp+1 3.將tmp賦值給countrem

要使用AtomicInteger.getAndIncrement()才能夠避免併發問題get

原子性操做與加鎖實例:class

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" );
    }

}

運行結果test

100000000 times increase synchronize time cost:2857 msimport

100000000 times increase atomic time cost:1033 ms

相關文章
相關標籤/搜索