栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

并发编程之深入理解JMM&并发三大特性(1) 20220324

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

并发编程之深入理解JMM&并发三大特性(1) 20220324

JMM

 线程A如果修改了共享变量,需写回到主内存,线程B是感知不到的,所以会出现可见性问题。 

一、并发和并行

目标都是为了提高CPU的利用率

1.并发指的是同一时刻只有一条指令执行,多个进程指令被快速的切换执行,用户无感知,实际上并不是同时执行,而是分成多个时间片执行。

2.并行指的是有多条指令在多个处理器上同时执行。

二、并发三大特性 并发编程Bug的源头:可见性、原子性和有序性问题 1.可见性 当一个线程修改了共享变量,其他线程立马能够看到修改的值 保证可见性的手段: volatile  内存屏障 synchronized Thread.yeild Lock Finla 底层原理就是两种方式 内存屏障 线程上下文切换 2.有序性 即程序执行的顺序按照代码的先后顺序执行。JVM 存在指令重排,所以存在有序性问题。 如何保证有序性 通过 volatile 关键字保证可见性。 通过 内存屏障保证可见性。 通过 synchronized关键字保证有序性。 通过 Lock保证有序性。 3.原子性 一个或多个操作,要么全部执行且在执行过程中不被任何因素打断,要么全部不执行。在 Java 中,对基本数据类型的变量的读取和赋值操作是原子性操作( 64位处理器)。不采取任 何的原子性保障措施的自增操作并不是原子性的。 如何保证原子性 通过 synchronized 关键字保证原子性。 通过 Lock保证原子性。 通过 CAS保证原子性。
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/777497.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号