为了账号安全,请及时绑定邮箱和手机立即绑定

细说Java多线程之内存可见性

难度中级
时长57分
学习人数
综合评分9.63
181人评价 查看评价
9.9 内容实用
9.6 简洁易懂
9.4 逻辑清晰
楼上的同学,我一开始也是这样的想法,然后我百度了一篇2016-06-19的原创博文,里面有这样一段补充:
(2)补充1
共享数据的访问权限都必须定义为private。一般是考虑安全性,对数据提供保护,可以通过set()方法赋值,再通过get()方法取值,这就是java封装的思想。
Java中对共享数据操作的并发控制是采用加锁技术。
Java中没有提供检测与避免死锁的专门机制,但应用程序员可以采用某些策略防止死锁的发生。
final也可以保证内存可见性。
博文的内容和老师讲的内容几乎是一样的,不知道是不是同一个人
授人以鱼不如授人以渔这句话完美的诠释了Marton老师,很多视频只会告诉你应该这样做而不说这样做的原因为什么要这样做。也可能因为我有点笨笨的吧
点个赞给老师
老师好厉害,讲的这不错,谢谢老师
感谢老师,课讲得生动、形象。
不变式是啥玩意
为我面试加分,谢谢老师
jls666
讲错了,线程中怎么可能还保存副本
不会才学,会了还在学毛线,有些人比别人早知道两天就开始装上了喘上了,很好奇你这样在公司混的开吗?
感觉JMM的内存模型和多核并行中UMA和NUMA有些相似之处。多核并行中,对于局部的缓存或者是chach中的更新策略有两种:写无效和写更新,写无效是一种懒加载,即当一个核下的缓存被修改之后,在公共的内存和其他的核的副本处打上数据失效的标识,如果其他的核在访问自己的缓存的时候发现了这个标识,就要去主动更新它。写更新是指当一个核修改了自己的缓存后,会及时的更新其他的副本。JMM的处理过程和写更新实在太相似了!
http://www.jianshu.com/u/1f0067e24ff8 jvm和并发编程相关的blog
讲的很好,希望后后续大点的课程或者项目推出
0,6的结果,也可能是读线程和写线程start后,谁先被cpu调度引起的。好像只加synchronized不能控制0,6的结果。需要利用线程同步的知识来解决。而sleep那个利用主线程阻塞的方式,很危险。那个sleep完全是经验值。如果写线程本身函数方法执行时间用时超过sleep时间或用时不定,结果就又会乱了。
课程须知
学习本课程前,你需要熟练掌握Java的基础语法,熟悉Java多线程的基础知识,以及synchronized实现线程同步的方法。
老师告诉你能学到什么?
1、内存可见性 2、指令重排序 3、as-if-serial语义 4、synchronized实现可见性 5、volatile实现可见性

微信扫码,参与3人拼团

意见反馈 帮助中心 APP下载
官方微信
友情提示:

您好,此课程属于迁移课程,您已购买该课程,无需重复购买,感谢您对慕课网的支持!

本次提问将花费2个积分

你的积分不足,无法发表

为什么扣积分?

本次提问将花费2个积分

继续发表请点击 "确定"

为什么扣积分?

举报

0/150
提交
取消