java并发编程

java并发编程

并行与并发

宏观串行,微观并行.

一般将线程轮流使用CPU叫做并发.

多核CPU下,每个核都可以调度线程,这时就叫做并行.

并发:一个人做多件事,轮流做.

并行:多个人做多件事,互不干涉

多线程

java一开始就支持多线程的能力.

可以解决性能问题

为什么可以解决性能问题?

提升性能的本质,就是压榨他的硬件(使用率)

例子: BIO阻塞式IO,操作IO时CPU处于空闲状态

多线程并发问题

如果一个线程正在进行写操作时,又有一个线程同时对这个内存进行读操作,这时,读到的数据是修改后的数据,或是原始数据,又或是半原始半修改数据.

多线程带来的问题?

安全性,性能(硬件)

死锁

可见性,原子性,有序性

java内存模型(JMM)

CPU—内存—IO

三者之间的读写速度的差异

CPU增加了缓存—目的是均衡与内存之间的速度差异

任务细化到线程, 切换执行

cpu对我们指令代码的顺序进行优化(重排)

为了线程使用数据更快速,会把线程中使用到的变量复制到线程的工作内存中.

线程间的数据时不可见的.

JVM主内存与工作内存:

主内存主要包括本地方法区和堆.

每个线程都有一个工作内存,工作内存有俩个部分:

一是属于该内存私有的栈

二是对主内存部分变量拷贝的寄存器

  1. 所有的变量都存储在主内存中(虚拟机内存的一部分),对所有线程都是共享的
  2. 每个线程都有自己的工作内存,工作内存中主要保存主内存中某些变量的拷贝,所有的变量操作都在工作内存中,而不能直接在主内存中读写变量
  3. 线程之间无法直接访问对方的工作内存的变量,都是通过主内存来完成.

Java特性:原子性、可见性、有序性

可见性:

一个线程对共享内存操作,另一个线程可以立即看到,我们称为可见性.

问题:

有个共享变量a=0,假设有俩个线程A和B,第一次都是获取a=0;A进行a++操作后a=1;但是B看不见这个操作,也是进行a++操作后a=1;这时变量的值为a=1,而不是我们所预期的a=2.

解决:

可以对共享变量加上关键字volatile;这时当线程A对其进行操作后,B可以立即看到就会将a改为1进行操作.

有序性:

指的是程序在执行时,程序的执行顺序和代码的顺序一致

原子性:

一个或多个操作在CPU执行时不会被中断.

原子性拒绝多线程交叉操作,只要具有原子性的变量,不管是单核还是多核.同一时刻只有一个线程对其操作

总结:

缓存导致的可见性问题,线程切换导致的原子性问题,编译优化导致的有序性问题

其实缓存,线程,编译优化目的都是提高程序性能和安全性.

volatile关键字:

一旦共享变量被volatile修饰后

  1. 一个线程对其进行操作后,其他线程是可见的
  2. 禁止进行指令重排
  3. 不能保证对变量操作的原子性
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值