多线程三大特性——可见性

本文详细介绍了Java多线程中的可见性问题,解释了JMM(Java内存模型)如何确保线程间共享变量的正确通信。讨论了happens-before原则、volatile关键字以及synchronized的作用,它们分别提供了对可见性的保障,确保线程能够看到其他线程对共享变量的更新。通过对这些概念的深入理解,开发者可以更好地处理多线程环境中的并发问题。
摘要由CSDN通过智能技术生成

JMM

JMM对共享内存的操作做出了如下两条规定:

  • 线程对共享内存的所有操作都必须在自己的工作内存中进行,不能直接从主内存中读写;
  • 不同线程无法直接访问其他线程工作内存中的变量,因此共享变量的值传递需要通过主内存完成。

可见性问题

在多线程应用程序中,线程对非易失性变量(non-volatile variables进行操作,出于性能原因,每个线程在处理变量时会将变量从主内存复制到CPU缓存中。如果您的计算机包含多个CPU,每个线程可能运行在不同的CPU上。这意味着,每个线程可以将变量复制到不同CPU的CPU缓存中。

Threads may hold copies of variables from main memory in CPU caches.

假设两个或多个线程访问一个共享对象,该对象包含如下声明的计数器变量:

public class SharedObject {

    public int counter = 0;

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值