论坛
潜水/灌水快乐,沉淀知识,认识更多同行。
ToB圈子
加入IT圈,遇到更多同好之人。
朋友圈
看朋友圈动态,了解ToB世界。
ToB门户
了解全球最新的ToB事件
博客
Blog
排行榜
Ranklist
文库
业界最专业的IT文库,上传资料也可以赚钱
下载
分享
Share
导读
Guide
相册
Album
记录
Doing
搜索
本版
文章
帖子
ToB圈子
用户
免费入驻
产品入驻
解决方案入驻
公司入驻
案例入驻
登录
·
注册
只需一步,快速开始
账号登录
立即注册
找回密码
用户名
Email
自动登录
找回密码
密码
登录
立即注册
首页
找靠谱产品
找解决方案
找靠谱公司
找案例
找对的人
专家智库
悬赏任务
圈子
SAAS
IT评测·应用市场-qidao123.com
»
论坛
›
数据库
›
Oracle
›
Java并发小结01
Java并发小结01
伤心客
论坛元老
|
2023-3-14 15:56:00
|
显示全部楼层
|
阅读模式
楼主
主题
1029
|
帖子
1029
|
积分
3087
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要
登录
才可以下载或查看,没有账号?
立即注册
x
Java并发小结01
主要参考自《实战Java高并发程序设计》。
复制代码
需要知道的概念
- 同步与异步
- 并发与并行
- 临界区
- 阻塞与非阻塞
- 死锁、饥饿、活锁
复制代码
同步与异步
同步:同步方法一旦被调用,必须等待方法返回后才能继续后续的行为。
异步:异步方法就像一个消息传递,被调用后方法会立即返回,调用者可以开始后续的行为。
复制代码
并发与并行
并行:两个任务同时执行。
并发:一段时间内,多个任务在CPU交替执行,看似并行。
复制代码
临界区
用来表示一种可以被多个线程使用的公共资源,但是一次只能一个线程使用。一旦临界区被占用,其他线程只能等待。
比如说打印机:一次只能打印一份文件,要是交替打印,那么打印出来的东西是不可用的。
复制代码
阻塞与非阻塞
阻塞:一个线程占用了临界区资源,其他线程需要这个资源就得等待,等待会导致线程挂起,这就是阻塞。
非阻塞:与阻塞相反,没有一个线程可以导致其他线程阻塞,所有线程都不断尝试继续执行。
复制代码
死锁、饥饿、活锁
死锁:两个或两个以上线程相互请求其他线程的资源,谁都执行不下去。
饥饿:一个线程因为种种原因一直获取不到需要的资源导致无法执行。
活锁:线程之间将资源相互推让而没有一个线程拿到资源继续执行。
复制代码
并发级别
- 阻塞
- 无饥饿
- 无障碍
- 无锁
- 无等待
复制代码
阻塞
使用synchronized关键字或重入锁,得到的就是阻塞的线程。
无饥饿
线程默认是不公平的(理论上优先满足优先级高的),会导致饥饿,公平锁解决饥饿问题。
无障碍
无障碍是一种最弱的非阻塞调度。两个线程如果无障碍地运行,那么不会因为临界区的问题导致一方被挂起。如果数据坏了就回滚,没有数据竞争就顺利完成工作,走出临界区。
无障碍有可能会因为数据冲突一直回滚,一种可行的无障碍实现可以依赖一个“一致性标记”来实现。
无锁
无锁的并行都是无障碍的。无锁的状态下,所有的线程都能尝试对临界区进行访问,不同的是,无锁的并发保证必然有一个线程能够在有限步内完成操作离开临界区。
会出现线程饥饿。
无锁的特点:可能会包含一个无穷循环。在这个循环中,线程会不断地尝试修改共享变量。如果没有冲突,修改成功,走人,否则继续尝试。
无等待
无锁只要求有一个线程在有限步内完成操作,而无等待则在无锁的基础上更近一步扩展。它要求所有线程都必须在有限步数内完成,这样就不会引起饥饿问题。
JMM
探讨一下java内存模型:原子性、可见性、有序性。
原子性:
一个操作是不可中断的。
可见性
一个线程修改了某个共享变量的值时,其他线程会立马知道这个修改。
有序性
程序在执行时,可能就进行指令排序,排序后的指令顺序与原指令顺序未必一致。
但是指令排序可以保证串行语义一致,不保证并行语义一致。
那些指令不能排序:Happen-Before原则
程序顺序原则:一个线程内保证语义的串行性。
volatile 原则:volatile变量的写先于读发生,这保证了volatile变量的可见性。
锁规则:解锁(unlock)必然发生在随后的加锁(lock)前面。
传递性:A先于B,B先于C,那么A先于C。
线程的start()方法先于它的每一个动作。
线程的中断(interrupt)先于被中断线程的代码。
对象的构造函数的执行、结束先于finalize()方法。
个人小结:
这些都是概念性问题,如果第一次不太熟悉可以baidu一下进行理解。
作为《实战Java高并发程序设计》的一章,主要介绍了并发的一些概念性关键词,建议深入理解,后面的多线程并发操作都建立在这些概念之上。
其中第一章有一个小结介绍有关并行的两个定律我忽略了,感兴趣的可以自己去看: Amdahl定律和Gustafson定律。
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
回复
使用道具
举报
0 个回复
正序浏览
返回列表
快速回复
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
or
立即注册
本版积分规则
发表回复
回帖并转播
发新帖
回复
伤心客
论坛元老
这个人很懒什么都没写!
楼主热帖
《百万IT毕业生的心声:IT专业大学生毕 ...
Java打怪之路----谷粒商场认证服务 ...
xtrabackup2版本和xtrabackup8版本对比 ...
Excelize 发布 2.6.1 版本,支持工作簿 ...
sqlserver导入sql文件的方式
原型设计工具比较及实践--滴爱音乐 ...
Snowflake(雪花算法),什么情况下会 ...
Flink-使用流批一体API统计单词数量 ...
SQL Server 2008下载及安装
基于 SpringBoot + MyBatis 的博客系统 ...
标签云
AI
运维
CIO
存储
服务器
浏览过的版块
Java
网络安全
物联网
快速回复
返回顶部
返回列表