原文:为什么synchronized无法禁止指令重排,却能保证有序性

为了进一步提升计算机各方面能力,在硬件层面做了很多优化,如处理器优化和指令重排等,但是这些技术的引入就会导致有序性问题。 先告诉面试官你知道什么是有序性问题,也知道是什么原因导致的有序性问题 我们也知道,最好的解决有序性问题的办法,就是禁止处理器优化和指令重排,就像volatile中使用内存屏障一样。 表明你知道啥是指令重排,也知道他的实现原理 但是,虽然很多硬件都会为了优化做一些重排,但是在Ja ...

2020-03-03 09:59 0 3458 推荐指数:

查看详情

volatile可以保证有序性

1.无volatile /**volatile 有序性验证 * @author xueci * */ public class TestSequence { static int a,b; static int x,y; public static void main ...

Wed Apr 22 23:23:00 CST 2020 1 652
为什么volatile能保证有序性不能保证原子

volatile适用场景值得一说的是volatile 变量的单次读/写操作可以保证原子的,如 long 和 double 类型变量,但不能保证 i++的原子,因为本质上 i++是读、写两次操作。在一些特殊的场景下可以代替 Synchronized。必须同时满足下面两个条件,才能保证线程安全 ...

Tue May 19 06:09:00 CST 2020 0 724
为什么volatile能保证有序性不能保证原子

对于内存模型的三大特性:有序性、原子、可见。 大家都知道volatile能保证可见有序性但是不能保证原子,但是为什么呢? 一、原子有序性、可见 1、原子: (1)原子的意思代表着——“不可分”;(2)在整个操作过程中不会被线程调度器中断的操作,都可认为是原子 ...

Sat Sep 14 00:51:00 CST 2019 6 3592
volatile如何保证可见有序性的?

volatile相当于轻量级锁 1,与锁不同的是,volatile不具有排他,也不会导致上下文切换. 2,与锁相同的是,JVM实现volatile的有序性和可见保证也是借助内存屏障. volatile变量写操作相当于释放锁,读操作相当于获得锁---JVM通过在volatile变量写之前 ...

Mon Jul 13 20:27:00 CST 2020 0 1435
Kafka系列四 之 多分区如何保证数据的有序性

Apache Kafka 消息怎么写? kafka是一个分布式的流消息队列 生产者将消息发布到某个主题 broker 进行存储 消费者 订阅+读数据 从该主题中 消息(记录)以序列化字 ...

Tue Dec 10 01:30:00 CST 2019 0 2687
 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM