首先 也是涉及到线程的安全与否:
这里主要是引入原子性操作概念 及如何运用自JDKJDK6 以后,新增加了的一个包java.util.concurrent.atomic。
原子性操作这种现象其实在平时码代码中就存在了,原子性操作即不可中断操作——赋值:int i = 5; 此类赋值操作
原子性操作 本就是线程安全的
比如:i++的操作 实质是由多个原子性操作组合而成的——先取值; 再加一; 再赋值 . 因此这种由多个原子性操作组合而成的操作就不是线程安全的
结合synchronized 关键字的作用 ——在一个线程类占用一个对象之后其他线程不得以占用必须等待其释放
类似理解一下 ——也就是一个线程在取i 的值结束后,还没有来得及进行加一操作,另一个线程也可以取 i的值了。
这也是分析同步问题产生的原因 中的原理。即涉及到了同步对象
i++ ,i–, i = i+1 这些都是非原子性操作。
只有int i = 1,这个赋值操作是原子性的。
介绍AtomicInteger原子类
AtomicInteger提供了各种自增,自减等方法,这些方法都是原子性的。 也就是 自增方法: incrementAndGet 是线程安全的,同一个时间,只有一个线程可以调用这个方法。
按照AtomicInteger类所给方法 incrementAndGet(); 会自动对静态变量h 进行自增操作
示例:
static int h=0;
static AtomicInteger at= new AtomicInteger();
public static void main(String[] args) {
for (int i = 0; i < T2.length; i++) {
Thread t2=new Thread() {
public void run ()
{
at.incrementAndGet();
}
};
t2.start();
T2[i]=t2;
}
for (int i = 0; i < T2.length; i++) {
try
{
T2[i].join();
}catch(InterruptedException e)
{
e.printStackTrace();
}
}
System.out.println("T2线程类未使用原子访问 之后其h的值为:"+at.intValue());
}
at.intValue()也是自动获取结果