在java中,除了同步的关键字之外,还提供了原子类,用来保证多线程环境下数据的同步性,此类称为原子变量类。
原子变量类比锁的粒度更细,量级更轻,并且对于在多处理器上实现高性能的并发是非常关键的。原子变量将发生竞争的范围缩小到单个变量上。在使用原子类时,方法也要是原子操作的,这样才能保证,同步方法执行原子类操作,数据资源是同步的。
代码实例:
package javaBase.thread.atomic;
import java.util.concurrent.atomic.AtomicInteger;
/**
* 原子类操作时保证数据同步需要在调用方法时加上同步
* @author wodezuiaishinageren
*
*/
public class AtomicProperty {
public static AtomicInteger num=new AtomicInteger(1);
/**
* 方法不同步时,原子操作也步能保证数据的安全
*/
public void addNum(){
// System.out.println("非同步线程"+Thread.currentThread().getName()+"num+100:"+num.addAndGet(100));
// num.addAndGet(1);
}
/**
* 同步方法原子类操作能保证数据的安全
*/
synchronized public void addNumSyn(){
System.out.println("同步线程"+Thread.currentThread().getName()+"num+100:"+num.addAndGet(100));
num.addAndGet(1);
}
}
package javaBase.thread.atomic;
/**
* 原子类线程操作
* @author wodezuiaishinageren
*
*/
public class AtomicPropertyThread extends Thread {
private AtomicProperty atomicProperty;
public AtomicPropertyThread(AtomicProperty atomicProperty){
this.atomicProperty=atomicProperty;
}
@Override
public void run(){
atomicProperty.addNumSyn();
}
}
package javaBase.thread.atomic;
/**
*
* @author wodezuiaishinageren
*
*/
public class AtomicPropertyTest {
public static void main(String[] args) throws InterruptedException {
AtomicProperty atomicProperty=new AtomicProperty();
AtomicProperty atomicProperty2=new AtomicProperty();
AtomicPropertyThread [] treadThreads=new AtomicPropertyThread[5];
for (int i = 0; i < treadThreads.length; i++) {
if(i%2==0){
treadThreads[i]=new AtomicPropertyThread(atomicProperty);
}else{
treadThreads[i]=new AtomicPropertyThread(atomicProperty2);
}
}
for (int i = 0; i < treadThreads.length; i++) {
treadThreads[i].start();
}
Thread.sleep(1000);
System.out.println(atomicProperty.num.get());
}
}