并发编程之深入理解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保证原子性。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值