《Java并发编程实践》总结

这学期开始我准备重新夯实一下Java基础,那么首当其冲的就是并发编程和Java虚拟机了,于是我在一个月的时间里终于把《Java并发编程实践总结》啃下来了,真的是啃,因为这本书对于没有多少并发编程经验的我来说实在晦涩难懂,以前做Android的时候网络编程还略微用过一点,现在学Java Web,Spring和Servlet都已经把多线程封装好了,没有什么机会用到,但是了解多线程的设计思想及其底层设计还是很重要的。

竞态条件

当某个计算的正确性取决于多个线程的交替执行时序时,就会发生竞态条件 。

竞态条件是并发编程出现问题的一大主因,“先检查后执行”操作就是竞态条件的最常见的类型,就是根据一个可能失效的结果来决定怎么进行下一步计算。

//竞态条件伪代码
if(一个可能为真可能为假的条件)
    操作A

在多线程环境下,在你确定条件为真并在操作A执行前,另一个线程又将条件置为假,这将此代码置于一种不稳定的状态,即有可能是对的也有可能是错的,全靠运气。

可重入

如果某个线程试图获得一个已经由它自己持有的锁,如果成功,则这个锁是可重入的,否则是不可重入的

重入锁的设计思想是每个锁关联一个计数值和一个线程。计数值为0,则没有任何线程持有该锁。若线程试图获取该锁而该锁计数值不为0时,则判断该线程是否是已经持有本锁的线程,如果是则获取成功,计数值+1。否则获取失败。线程每一次退出同步区时,计数值-1,当计数值为0时,该锁被释放。

内置锁不是可重入的,ReentrantLock则可以重入。

重排序

在编译器中生成的指令顺序,可以与源代码中的顺序不同

第一次看到重排序时,我就在想JVM这不是在乱搞吗,我辛辛苦苦写的代码,你还来给我重排序。后来了解到重排序提升了编译效率,但是重排序机制也不是对所有代码都重排序,操作A和操作B之间如果满足了偏序关系,即“Happens-Before”关系,那么JVM就不会对它们的代码进行重排序。

Volatile关键字

把变量声明为Volatile后,编译器会注意到这个变量是共享的,因此不会把该变量上的操作与其他内存操作一起重排序,例如在多线程中需要设置一个变量为循环条件时,最好将其设为volatile

volatile boolean asleep;
...
while(!asleep)
{
  .....
}

同步工具类

a.CountDownLatch

CountDownLatch称之为闭锁,可以使一个或多个线程等待一组事件的发生。CountDownLatch主要有两个方法,countDown()和await(),没调用一次countdown则计数值减一,await将一直阻塞直到计数值为0。

b.FutureTask

FutureTask表示的计算是通过Callable来实现的,相当于一种可生成结果的Runnable,并且可以处于以下三种状态:等待运行,正在运行,运行完成。FutureTask.get方法调用后如果该任务已经完成,则立即返回结果,否则一直阻塞到任务完成或者抛出异常。

无限制创建线程的不足

  • 线程生命周期的开销非常高。
  • 资源消耗
  • 稳定性因素,可能抛出OutOfMemoryError错误。

Executor

由于无限制创建线程并不是一种好的策略,于是我们可以使用有界队列来防止这一情况的产生,Executor就应运而生了。

Executor基于生产者消费者模式,如果要在程序中实现一个生产者消费者模式,最简单的方法就是使用Executor。

线程池

线程池可以复用多个线程从而分摊线程创建和销毁过程中的巨大开销,由于任务到来时线程已经存在了从而还提高了响应性,可以调用Executors中的几个静态方法来创建一个线程池。

  • newCachedThreadPool()

    线程池的规模无限制,线程超过需求就创建,小于需求就回收

  • newFixedThreadPool(int)

    线程池的规模是固定的

  • newScheduledThreadPool(int)

    固定长度的线程池,以延时或定时的方式执行任务

  • SingleThreadExecutor()

    只包含一个线程的线程池

饱和策略

前面说了线程池使用有界队列来管理线程,如果饱和了怎么办呢?就需要用到提前定义的饱和策略:

  • AbortPolicy: 直接抛出异常,由调用者自己捕获编写处理代码。
  • DiscardPolicy: 不处理该任务,直接丢弃
  • DiscardOldestPolicy: 丢弃队列里最近的一个任务,并执行当前任务。
  • CallerRunsPolicy: 只用调用者所在线程来运行任务。

显式锁

Lock和ReentrantLock

Lock和ReentrantLock与内置锁的区别是可以中断一个正在等待获取锁的线程,或者使该线程无限地等待下去,Lock和ReentrantLock必须在finally代码块中释放锁,否则一直持有锁就极易形成死锁

读写锁

读写锁其实是由两个Lock组成的

public interface ReadWriteLock
{
  Lock readLock();
  Lock writeLock();
}

在读写锁的加锁策略中,允许多个读操作同时进行,但每次只允许一个写操作。

以上就是我读第一遍的部分收获,此书太过经典,第一遍我大概只掌握了40%的知识,等以后有时间了再二刷。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,684评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,143评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,214评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,788评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,796评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,665评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,027评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,679评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,346评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,664评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,766评论 1 331
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,412评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,015评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,974评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,073评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,501评论 2 343

推荐阅读更多精彩内容

  • layout: posttitle: 《Java并发编程的艺术》笔记categories: Javaexcerpt...
    xiaogmail阅读 5,793评论 1 19
  • 第1章 并发编程的挑战 1.1 上下文切换 即便是单核CPU也支持多线程并发,CPU通过给每个线程分配时间片(几十...
    卑鄙的鹿尤菌阅读 4,737评论 1 22
  • 上周的面试中,被问及了几个并发开发的问题,自己回答的都不是很系统和全面,可以说是“头皮发麻”,哈哈。因此果断购入《...
    想象美阅读 531评论 1 4
  • 最近,大家被这部剧耍爆了吧... 里面颜王孙红雷除了时常神兜兜发傻以外,最出彩的就是化身米其林三星大厨,秀各种厨艺...
    61c64b8b9616阅读 415评论 0 0
  • 雨后。麦苗疯长 朝着天空的方向,熙熙攘攘 河流孤独的流向远方,水流无声 穿行在这岸边的麦田 没有一匹马或者蝴蝶陪伴...
    穗心说语阅读 526评论 0 3