专栏首页JVMGCJava多线程之有序性
原创

Java多线程之有序性

有序性

在Java内存模型中,允许编译器和处理器对指令进行重排序,但是重排序过程不会影响单线程执行的结果,会影响到多线程并发执行结果的正确性

volatile,synchronized,Lock通过volatile,synchronized,Lock保证一定的有序性,synchronized,Lock保证每一时刻只有一个线程可以执行同步代码块,相当于让线程顺序执行同步代码,从而保证有序性。另外,JVM具备一些先天的有序性,即不需要额外的手段就能保证有序性,即Happens-before原则,如果两个操作的执行次序,没有办法通过Happens-before原则推导出来,虚拟机进行随意的重排序,那么就不能保证有序性。

Happens-before

1.如果一个操作Happens-before另外一个操作,那么第一个操作的执行结果相对第二个操作可见,并且第一个操作的执行顺序在第二个操作之前执行。

2.两个操作之间存在Happens-before关系,并不意味着一定要按Happens-before原则制定的顺序执行。如果重排序之后的执行结果与Happens-before关系执行的结果一致,那么这种重排序就不非法。

下面是Happens-before的规则

  • 程序次序规则:一个线程内,按照代码顺序,书写在前面的操作先行发生于书写在后面的操作;
  • 锁定规则:一个unLock操作先行发生于后面对同一个锁额lock操作;
  • volatile变量规则:对一个变量的写操作先行发生于后面对这个变量的读操作;
  • 传递规则:如果操作A先行发生于操作B,而操作B又先行发生于操作C,则可以得出操作A先行发生于操作C;
  • 线程启动规则:Thread对象的start()方法先行发生于此线程的每个一个动作;
  • 线程中断规则:对线程interrupt()方法的调用先行发生于被中断线程的代码检测到中断事件的发生;
  • 线程终结规则:线程中所有的操作都先行发生于线程的终止检测,我们可以通过- - Thread.join()方法结束、Thread.isAlive()的返回值手段检测到线程已经终止执行;
  • 对象终结规则:一个对象的初始化完成先行发生于他的finalize()方法的开始;
wx.jpg

原创声明,本文系作者授权云+社区发表,未经许可,不得转载。

如有侵权,请联系 yunjia_community@tencent.com 删除。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Java多线程的可见性与有序性

    如果一个变量在多个线程的工作内存中都存在副本,那么这个变量就是这几个线程的共享变量。

    全菜工程师小辉
  • Java之多线程买票程序

    一共100张票,每个售票窗口卖票的数量大致相同(20)张卖票时给与编号,每张票唯一。

    静谧星空TEL
  • Java多线程之可见性之volatile

    入门小站
  • Java多线程:线程属性

    喜欢天文的pony站长
  • 【Java线程】线程安全三元素:原子性、可见性、有序性

    首先大家需要思考一下何为线程安全性呢??? 《Java并发编程实战》书中给出定义:当多个线程访问某个类时,不管运行时环境采用何种调度方式或者这些线程将如何交替...

    沁溪源
  • 高并发之——多线程的三大特性(原子性、可见性和有序性)

    作者个人研发的在高并发场景下,提供的简单、稳定、可扩展的延迟消息队列框架,具有精准的定时任务和延迟队列处理功能。自开源半年多以来,已成功为十几家中小型企业提供了...

    冰河
  • java之多线程(Thread)

    1 package DEMO; 2 //主线程 3 public class Example12_2 { 4 public static void ...

    Gxjun
  • Java多线程之CAS

    CAS字面意思为比较并交换.CAS 有 3 个操作数,分别是:内存值 M,期望值 E,更新值 U。当且仅当内存值 M 和期望值 E 相等时,将内存值 M 修改为...

    Java宝典
  • Java多线程之CAS

    CAS字面意思为比较并交换.CAS 有 3 个操作数,分别是:内存值 M,期望值 E,更新值 U。当且仅当内存值 M 和期望值 E 相等时,将内存值 M 修改为...

    Java宝典
  • java多线程之Phaser

    前面的文章中我们讲到了CyclicBarrier、CountDownLatch的使用,这里再回顾一下CountDownLatch主要用在一个线程等待多个线程执行...

    程序那些事
  • Java并发编程与高并发之线程安全性(原子性、可见性、有序性)

    1、并发的基本概念:同时拥有两个或者多个线程,如果程序在单核处理器上运行,多个线程将交替地换入或者换出内存,这些线程是同时存在的,每个线程都处于执行过程中的某个...

    别先生
  • 多线程之线程可见性synchronized

    入门小站
  • java多线程有什么作用?使用java多线程有什么好处?

    谈到java多线程,很多人都会感到非常头疼,java多线程不仅理论知识非常深奥,运用起来也很麻烦,但是它所能发挥的作用却是不可小觑的,下面简单为大家介绍一下ja...

    用户8739405
  • 多线程编程学习十二(原子性、可见性与有序性)

    原子(atom)指化学反应不可再分的基本微粒,原子在化学反应中不可分割。原子操作指的是不可分割的整体,多线程的原子性指的是没有其他线程能够中断或检查正在原子操作...

    JMCui
  • Java多线程之细说线程池

    前言   在认识线程池之前,我们需要使用线程就去创建一个线程,但是我们会发现有一个问题:    如果并发的线程数量很多,并且每个线程都是执行一个时间很短的任务就...

    用户1195962
  • Java并发性和多线程

    例如一个应用程序需要从本地文件系统中读取和处理文件的情景. 比方说, 从磁盘读取一个文件需要5s, 处理一个文件需要2s. 那么处理两个文件就需要:

    烟草的香味
  • Java 多线程 从无到有

    个人总结:望对屏幕对面的您有所帮助 ? 一. 线程概述 进程: 有独立的内存控件和系统资源 应用程序的执行实例 启动当前电脑任务管理器:taskmgr 进程是...

    房上的猫
  • Java多线程编程笔记之多线程技能

    1.进程和线程的概念及线程的优点 进程是程序在一个数据集合上运行的过程,是系统进行资源分配和调度的一个独立单位。 线程可以理解成是进程中独立运行的子任务。 线程...

    JavaQ
  • Java多线程之<<守护线程>>实战

    定义 什么是守护线程?与守护线程相对应的就是用户线程,守护线程就是守护用户线程,当用户线程全部执行完结束之后,守护线程才会跟着结束。也就是守护线程必须伴随着用户...

    Java技术栈

扫码关注云+社区

领取腾讯云代金券