
并发编程学习
baiduwangpan1
这个作者很懒,什么都没留下…
展开
专栏收录文章
- 默认排序
- 最新发布
- 最早发布
- 最多阅读
- 最少阅读
-
Java并发编程艺术---java并发编程机制的底层实现原理
2.1volatile的应用 volatile是轻量级的synchronized,它在多处理器开发中保证了变量的“可见性”。由于使用volatile不会引起线程的上下文切换,所以如果使用得当,会比synchronized的使用和执行成本更低。 2.1.1volatile的定义与实现原理 对volatile修饰的变量进行反编译的时候,可以看到会有一个lock前缀的指令,这个指令在多核处理器下回做如下两件事情: (1)将当前处理器缓存行的数据写回到系统内存。 (2)这个写回内存的操作会使在其他CPU里缓存了该内原创 2020-05-13 10:16:48 · 222 阅读 · 1 评论 -
JAVA并发编程的艺术---第一章:并发编程的挑战
1.1上下文切换 从人物保存到再加载的过程就是一次上下文切换 1.1.1 多线程一定快吗 答案是不一定的,当并发执行累加操作不查过百万次时,速度会比串行执行累加操作要慢。 为什么并发执行速度会比串行慢?这是因为线程有创建和上下文切换的开销。 可是使用Lmbench3测试上下文切换的时长。 使用vmstat可以测量上下文切换的次数。 1.1.3如何减少上下文切换 无锁并发编程 CAS算法 使用最少线程 协程:在单线程里实现多任务的调度,并在单线程里维持多个任务间的切换。 1.1.4减少上下文切换实战 通过减少原创 2020-05-12 19:45:02 · 232 阅读 · 0 评论 -
并发编程学习第二章
(1)无状态对象永远是线程安全的。 (2)竞争条件:检查再运行,使用一个潜在的过期值作为决定下一步操作的依据。 (3)检查再运行的常见手法:惰性初始化。 惰性初始化中的竞争条件会破坏其正确性。 ...原创 2020-04-24 12:25:16 · 189 阅读 · 0 评论 -
并发编程学习第一章
第一章线程的风险 相关名词解释: (1)活跃度:安全意味着“什么坏事都没有发生”,而活跃度关注的是“好事情最终发生了”。当一个活动进入到某种它永远无法再继续执行的状态时活跃度失败就发生了。 (2)远程方法调用:RMI使你能够调用在另外一个JVM上运行的对象的方法。 ...原创 2020-04-23 23:10:01 · 157 阅读 · 0 评论