package im.zxd.test;
public class LongTest {
public static long num = 0;
public static final long value1=-1L;
public static final long value2=0;
public static void main(String[] args) {
Thread t1=new Thread(new Runnable() {
public void run(){
while(true){
num=value1;
}
}
});
Thread t2=new Thread(new Runnable() {
public void run(){
while(true){
num=value2;
}
}
});
t1.start();
t2.start();
while(true){
long value=num;
if(value!=value1&&value!=value2){
System.out.println("赋值出现了 异常值");
System.out.println("二进制:"+Long.toBinaryString(value));
System.out.println("异常值:"+value);
break;
}
else{
System.out.println("value"+ num);
}
}
}
}
运行这段代码后,打印如下的值:
这种情况是在 32jdk 中给64 变量 long 的时候出现的问题,原因就是 32jdk 操作64变量long的时候,是两次操作完成 的。
先给32位赋值,然后给剩下的32位赋值,当多个线程出现竞争的时候,会出现A线程赋值了一般(32位),B线程给另一半(32位)赋值了,就出现了 例子里出现的情况。 前面32位是 -1的值,后32位是0的值,结果 出现了-4294967296这样的值。
这种情况,只要保证 变量在赋值的时候,A线程操作完全结束后,B线程才进行赋值操作,这样就可以避免这种情况。java中用
volatile 关键字修饰就可以解决这种问题,当然也可以加锁来使变量的操作串行。
----------------------------闲着没事儿 写个例子增强记忆