美文网首页编程语言Android
内存屏障和同步屏障傻傻分不清楚

内存屏障和同步屏障傻傻分不清楚

作者: 程序员小迷 | 来源:发表于2024-05-18 13:02 被阅读0次

一、Java 中如何保证底层操作的有序性和可见性?

1.解决方案:内存屏障。

2.有序性:内存屏障是可以插入到两个CPU指令之间的一种指令,用来禁止处理器指令发生重排序,从而保障 有序性(确保指令的执行顺序与代码中的顺序一致)。

3.可见性:为了达到屏障的效果,内存屏障也会使处理器写入、读取值之前,将主内存的值写入高速缓存,清空无效队列,从而保障 可见性。

4.实现:

1)在Java中,内存屏障可以通过硬件或者软件实现。

在硬件层面,CPU会提供一些专门的指令来实现内存屏障。

在软件层面,例如使用sun.misc.Unsafe类中的loadFence和storeFence方法。

Java中的volatile和synchronized关键字会使用内存屏障来保证内存操作的有序性和可见性。

2)在C/C++中,编译器指令如volatile、__sync_synchronize()以及特定处理器的内存屏障指令(如x86的mfence)可以用来实现内存屏障。

5.内存屏障能保证有序性和可见性,但不能保证原子性。

二、volatile内存屏障插入策略:

在Java内存模型(Java Memory Model即JMM)中,内存屏障是通过插入特定的JVM指令实现的。

1.在每个volatile写操作的前面插入一个StoreStore屏障。

2.在每个volatile写操作的后面插入一个StoreLoad屏障。

3.在每个volatile读操作的前面插入一个LoadLoad屏障。

4.在每个volatile读操作的后面插入一个LoadStore屏障。

三、StoreLoad 屏障:

对于这样的伪代码语句 Store1; StoreLoad; Load2,在 Load2 及后续所有读取操作执行前,保证 Store1 的写入对所有处理器可见。StoreLoad屏障的开销是四种屏障(其它3种屏障为LoadLoad、LoadStore、StoreStore)中最大的(冲刷缓冲器,清空无效队列)。在大多数处理器的实现中,这个屏障是个万能屏障,兼具其它三种内存屏障的功能。

四、synchronized关键字的作用

1.synchronized关键字能保证有序性、可见性、原子性。

2.对于 synchronized关键字包住的代码区域,当线程进入到该区域读取变量信息时,能保证读到的是主内存中最新的值。这是因为在同步区内对变量的写入操作,在离开同步区时就将当前线程内的数据刷新到主内存中,而对数据的读取也不能从缓存读取,只能从主内存中读取,这样就保证了数据的读写有效性。

五、Android中的同步屏障

Android中分发的消息通常都是同步消息,当需要优先处理重要的异步消息时,可以设置同步屏障,使程序只能处理异步消息而不能处理同步消息。

//async为true时Handler发送的是异步消息

public Handler(boolean async)

//async为true时将消息设置为异步消息

Message.setAsynchronous(boolean async)


微风不燥,阳光正好,你就像风一样经过这里,愿你停留的片刻温暖舒心。

我是程序员小迷(致力于C、C++、Java、Kotlin、Android、Shell、JavaScript、TypeScript、Python等编程技术的技巧经验分享),若作品对您有帮助,请关注、分享、点赞、收藏、在看、喜欢,您的支持是我们为您提供帮助的最大动力。

欢迎关注。助您在编程路上越走越好!

相关文章

  • leveldb源码学习--skiplist

    Skiplist原理 内存屏障 内存屏障,也称内存栅栏,内存栅障,屏障指令等,是一类同步屏障指令,是CPU或编译器...

  • 内存屏障在CPU、JVM、JDK中的实现

    前言 内存屏障(英语:Memory barrier),也称内存栅栏,内存栅障,屏障指令等,是一类同步屏障指令,它使...

  • Handler 同步屏障造成ANR分析

    问题 Handler同步屏障是否会导致ANR? 结论 同步屏障的使用有可能会导致ANR 分析 什么是同步屏障同步屏...

  • 什么是内存屏障?

    内存屏障:是一种CPU质量,用于控制特定条件下的重排序和内存可见性问题。又称:内存栅栏 内存屏障作用: 阻止屏障两...

  • Android-Handler同步屏障

    一、消息机制之同步屏障 消息机制的同步屏障,其实就是阻碍同步消息,只让异步消息通过。而开启同步屏障的方法就是调用下...

  • Java并发-26.并发工具类-CyclicBarrier

    同步屏障CyclicBarrier让一组线程到达一个屏障(同步点)时阻塞,直到最后一个线程到达屏障时,屏障打开,所...

  • 同步屏障CyclicBarrier的理解和使用

    一、同步屏障简介 同步屏障CyclicBarrie的作用顾名思义,就是为所有线程设置一个屏障,等大家都同步后,再一...

  • Java的final关键字的内存语义

    概念介绍: 1.内存屏障: 内存屏障(Memory Barier,或者有时叫做内存栅栏,Memory Fence)...

  • (十四)内存屏障

    重排 内存屏障 内存屏障种类 编译器和处理器必须同时遵守重排规则。多核处理器需使用内存屏障指令来确保一致性。即使编...

  • 内存屏障

    内存屏障(Memory Barrier,或有时叫做 内存栅栏,Memory Fence)是一种CPU指令,用于控制...

网友评论

    本文标题:内存屏障和同步屏障傻傻分不清楚

    本文链接:https://www.haomeiwen.com/subject/bknwfjtx.html