java并发编程(1):并发编程框架简介

1、Executor框架

Executor框架构建线程池及任务调度处理。

Executor框架.png

Executor接口:线程执行的基本接口,用户通过此接口提交任务给线程或线程池执行;
ExecutorSevice接口:线程池相关操作接口,定义了线程池的维护、任务提交及状态维护等相关接口;
AbstractExecutorService抽象类:ExecutorSevice接口的抽象实现;
ThreadPoolExecutor线程池类:线程池的具体实现类,实现了线程池的创建、维护等,任务的提交、任务队列的维护、任务的分发执行等相关操作。
ScheduledThreadPoolExecutor:继承于ThreadPoolExecutor的实现类,可基于时间延时或时间间隔进行任务执行和调度等;
ForkJoinPool:继承于AbstractExecutorService,基于任务拆分结果聚合的架构;
DelegatedExecutorService:由Executors工具类实现,ExecutorService的包装器类,使得ExecutorService不可变;
FinalizableDelegatedExecutorService:由Executors工具类实现,实现了finalize()方法的DelegatedExecutorService类;
DelegatedScheduledExecutorService:由Executors工具类实现,基于时间延迟和时间间隔调度的DelegatedExecutorService类;

2、Future框架

Future封装异步执行结果等数据;

Future框架.png

Future:封装异步执行的结果及任务状态等;
RunnableFuture:继承于Runnable及Future接口;
FutureTask:封装了线程、任务、任务状态维护、任务结果、等待队列等相关信息;
ScheduledFutureTask:继承于FutureTask,同时保存了任务调度时间相关信息。
ForkJoinTask:封装了任务拆分及结果聚合相关处理;

3、BlockingQueue阻塞队列

BlockingQueue为任务队列,是任务生产和线程消费的缓存通道。

BlockingQueue阻塞队列.png

BlockingQueue:阻塞队列接口,封装对象添加及获取的相关接口;
ArrayBlockingQueue:基于数组实现的阻塞队列;
LinkedBlockingQueue:基于队列实现的阻塞队列;
PriorityBlockingQueue:支持优先级的阻塞队列;
DelayedWorkQueue:基于时间延迟的排序的队列,主要在ScheduledThreadPoolExecutor中使用。

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

推荐阅读更多精彩内容

  • 一.线程安全性 线程安全是建立在对于对象状态访问操作进行管理,特别是对共享的与可变的状态的访问 解释下上面的话: ...
    黄大大吃不胖阅读 779评论 0 3
  • 一、并发 进程:每个进程都拥有自己的一套变量 线程:线程之间共享数据 1.线程 Java中为多线程任务提供了很多的...
    SeanMa阅读 2,266评论 0 11
  • https://blog.csdn.net/defonds/article/details/44021605/ 译...
    huangxiongbiao阅读 1,198评论 0 11
  • 1.简介 如果并发的线程数量很多,并且每个线程都是执行一个时间很短的任务就结束了,这样频繁创建线程就会大大降低系统...
    htkeepmoving阅读 491评论 0 2
  • 把子女培养成“听话”的孩子,是父母转嫁了自己的焦虑,同时也给孩子带来了严重的心理问题。这是双输局面,对谁也没有好处...
    精灵儿飞阅读 237评论 1 1