Java多线程 结果错误:a++会让加的次数减少
发布日期:2021-06-30 13:12:04
浏览次数:3
分类:技术文章
本文共 1128 字,大约阅读时间需要 3 分钟。
文章目录
a++会让加的次数减少
如下的代码演示了, 原本期望是20000的结果, 却由于线程不安全, 导致了结果不符合预期.
创建了两个线程, 都去调用run方法的共享变量的i++的操作.
并且使用了join让主线程等待子线程. 主线程等待子线程执行完毕之后, 再打印执行的结果./** * 类名称:MultiThreadsError * 类描述: 第一种:运行结果出错。 演示计数不准确(减少),找出具体出错的位置。 * * @author: https://javaweixin6.blog.csdn.net/ * 创建时间:2020/8/31 19:18 * Version 1.0 */public class MultiThreadsError implements Runnable{ static MultiThreadsError instance = new MultiThreadsError(); int index = 0; public static void main(String[] args) throws InterruptedException { Thread thread1 = new Thread(instance); Thread thread2 = new Thread(instance); thread1.start(); thread2.start(); //主线程 等待子线程 thread1.join(); thread2.join(); //打印结果 System.out.println(instance.index); } @Override public void run() { for (int i = 0; i < 10000; i++) { index++; } }}
运行两次程序 可以看到分别打印如下. 结果是不一致的, 这就出现了线程不安全的现象.
加的次数减少原因分析
主要的原因是i++的操作, 看似是一条语句, 但其实是3条语句,
先要获取i的值, 再加1 ,最后再把加好的值,赋值给i. 那么就可能出现, 在线程1 执行了加1操作的时候, 还没把最新的值赋值给i , cpu调度就把执行权给了线程2 , 导致原本此时应该是i是2的,但是却获取到的是1的值. 这样就导致了加的值变小了. 如下图的的箭头执行流程,转载地址:https://javaweixin6.blog.csdn.net/article/details/108327742 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
留言是一种美德,欢迎回访!
[***.207.175.100]2024年04月29日 00时15分07秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
人工智能为什么这么火?看看安防江湖30年血战就知道了
2019-05-01
“中国已建成世界上最大的视频监控网”背后的问题
2019-05-01
一个ps解复用H264和H264打包ps的动态库及demo
2019-05-01
“前端智能为安防产生新的数据价值”
2019-05-01
visual studio 2017社区版 离线安装包下载地址
2019-05-01
谁能阻挡亚马逊吞下数字时代最后一块蛋糕?
2019-05-01
第三方资源下载路径集合
2019-05-01
Docker修改空间大小
2019-05-01
docker端口映射
2019-05-01
Docker -v 对挂载的目录没有权限 Permission denied
2019-05-01
docker:(3)docker容器挂载宿主主机目录
2019-05-01
浅谈docker Dockerfile 指令 VOLUME 介绍
2019-05-01
关于Docker默认存储位置及Docker系统默认池存储、卷存储限制空间修改
2019-05-01
Docker 空间大小设置
2019-05-01
anaconda python 版本对应关系
2019-05-01
docker学习5--docker数据卷(volume)
2019-05-01
tensorflow版本定义说明
2019-05-01
Github 项目 - mmdetection 模型训练
2019-05-01
Linux 添加开机启动服务
2019-05-01
AMD显卡透传
2019-05-01