java - 线程同步为什么不一样
问题描述
package com.dome;
public class Thread01 {
private volatile static int a =10;Thread td1 = new Thread(){public void run(){for(int i=0;i<3;i++){ a = a+1;System.out.println(i+'td1:='+a);} } };Thread td2 = new Thread(){ public void run(){for(int i=0;i<3;i++){ a -=1; System.out.println(i+'td2:='+a);} } };public static void main(String[] args) { Thread01 th = new Thread01(); th.td1.start();th.td2.start(); }
}
0td1:=90td2:=91td1:=101td2:=92td1:=102td2:=9
问题解答
回答1:a = a + 1, a = a - 1 这样的语句,事实上涉及了 读取-修改-写入 三个操作:
读取变量到栈中某个位置
对栈中该位置的值进行加 (减)1
将自增后的值写回到变量对应的存储位置
因此虽然变量 a 使用 volatile 修饰,但并不能使涉及上面三个操作的 a = a + 1,a = a - 1具有原子性。为了保证同步性,需要使用 synchronized:
public class Thread01 { private volatile static int a = 10; Thread td1 = new Thread() {public void run() { for (int i = 0; i < 3; i++) {synchronized (Thread01.class) { a = a + 1; System.out.println(i + 'td1:=' + a);} }} }; Thread td2 = new Thread() {public void run() { for (int i = 0; i < 3; i++) {synchronized (Thread01.class) { a -= 1; System.out.println(i + 'td2:=' + a);} }} }; public static void main(String[] args) {Thread01 th = new Thread01();th.td1.start();th.td2.start(); }}
某次运行结果:
(td1 出现的地方,a 就 +1;td2 出现的地方,a 就 -1)
相关文章:
1. javascript - 如何让移动端网页的输入框固定在底部?2. angular.js - angularjs的自定义过滤器如何给文字加颜色?3. docker镜像push报错4. angular.js - angular内容过长展开收起效果5. 大家好,请问在python脚本中怎么用virtualenv激活指定的环境?6. MySQL中无法修改字段名的疑问7. linux - 升级到Python3.6后GDB无法正常运行?8. 请教各位大佬,浏览器点 提交实例为什么没有反应9. 网页爬虫 - 用Python3的requests库模拟登陆Bilibili总是提示验证码错误怎么办?10. 并发模型 - python将进程池放在装饰器里为什么不生效也没报错
