关于synchronized有趣的同步问题
更新时间:2019年01月09日 15:00:53 作者:李灿辉
今天小编就为大家分享一篇关于关于synchronized有趣的同步问题,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
在多线程对一个整数进行自增操作时,需要用synchronized进行同步。然而,如果synchronized的对象选取的不合适的话,就无法实现同步的效果。如下面的例子。
public class SyncThreadTest extends Thread {
public static Integer count = 0;
private static final int TIMES = 10000;
public SyncThreadTest(){
super("SyncThread");
}
@Override
public void run(){
synchronized (count){
for (int i = 0; i < TIMES; i ++){
count++;
}
}
}
public static void main(String[] args) throws InterruptedException{
SyncThreadTest t1 = new SyncThreadTest();
SyncThreadTest t2 = new SyncThreadTest();
t1.start();
t2.start();
t1.join();
t2.join();
System.out.println(count);
}
}
在上面的例子中,选取了自增的变量作为同步的对象。启动2个线程,各自对count自增10000次。最后的结果,count的值却不是20000次。
原因在于count对象一直处于改变当中,起不到两个线程的锁的作用。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。如果你想了解更多相关内容请查看下面相关链接
相关文章
Hadoop 使用IntelliJ IDEA 进行远程调试代码的配置方法
这篇文章主要介绍了Hadoop 使用IntelliJ IDEA 进行远程调试代码的配置方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2021-04-04


最新评论