code搬运工_深入多线程(v1)

Runnable与Callable接口的方式创建多线程的特点 :

  • 线程类只是实现了Runnable接口或Callable接口,还可以继承其它类
  • 在这种方式下 , 多个线程可以共享一个target对象 , 所以非常适合多个线程来处理同一份资源情况
  • 如果需要访问当前线程,需要使用Thread.currentThread方法
  • Callable接口与Runnable接口相比,只是Callable接口可以返回值而已(future)

Thread类的方式创建多线程的特点 :

  • 因为线程已经继承Thread类,所以不可以再继承其它类
  • 如果需要访问当前线程,直接使用this即可
    线程池

Thread 弊端 :

  • 性能差,缺乏统一管理,相互竞争,占用过多系统资源,导致死机或OOM

线程池ThreadPoolExecutor 优势 :

  • 重用线程,减少创建和销毁,性能好
  • 有效控制最大并发,提高系统资源利用率,避免过多资源竞争,避免阻塞
  • 提供定时定期执行、单线程、并发数控制的功能

相关参数 :

  • corePoolSize:核心线程数
  • maximumPoolSize:线程最大线程数
  • workQueue:阻塞队列,存储等待执行任务
  • KeepAliveTime:线程没有任务执行时最久保持多久时间终止
  • unit:KeepAliveTime的时间单位
  • threadFactory:线程工厂,用来创建线程
  • rejectHandler:当拒绝处理任务时策略

线程池状态 :

  • runing:接收新提交的任务和阻塞队列中任务
  • shutdown:关闭,不能接收新提交任务,可以处理阻塞队列中缓存任务
  • stop:关闭,不接收新提交任务和阻塞状态中的任务
  • tidying:任务结束,有效线程数数为0
  • terminated:线程池内部处理

相关方法 :

  • execute():提交任务,交给线程池执行
  • submit():提交任务,能够返回执行结果 execute+future
  • shutdown():关闭线程池,等待任务处理完
  • shutdownNow():关闭线程池,不等待任务处理完
  • getTaskCount():线程池已执行和未执行的任务总数
  • getCompletedTaskCount():已完成任务数量
  • getPoolSize():线程池当前线程数量
  • getActiveCount():当前线程中正在执行任务的线程数量

相关类库 :

  • Executors
  • ThreadPoolExecutor ScheduledThreadPoolExecutor

什么是线程池 :

  • 根据一组执行策略的调用、调度、执行和控制的异步任务框架
  • 提供一种任务提交和运行分离机制
  • 接口: Executor、ExcutorService、ScheduledExecutorService

四种线程池 :

  • newCachedThreadPool
    可缓存线程池,线程池长度超出需要,可以灵活处理空闲线程,没有可回收的则新建线程
    在线程池空闲时,即线程池中没有可运行任务时,它会释放工作线程,从而释放工作线程所占用的资源
    当出现新任务时,又要创建新的工作线程,这会带来一定的系统开销。
    并且在使用CachedThreadPool时,一定要注意控制任务的数量,否则大量线程同时运行,可能会造成系统瘫痪
  • newFixedThreadPool
    定长线程池,控制最大并发数,超出线程在队列等待
    具有线程池的高效率和节省创建线程时所耗的开销的优点。
    在线程池空闲时,即线程池中没有可运行任务时,
    它不会释放工作线程,还会占用一定的系统资源。
  • newScheduledThreadPool
    定长线程池,定时、周期性任务执行
  • newSingleThreadExecutor
    单线程化线程池,用唯一的线程执行任务,保证所有任务按照指定顺序执行若有多余的任务提交到线程池中,则会被暂存到阻塞队列.待空闲时再去执行。按照先入先出的顺序执行任务。
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,546评论 6 507
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,224评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,911评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,737评论 1 294
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,753评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,598评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,338评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,249评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,696评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,888评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,013评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,731评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,348评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,929评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,048评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,203评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,960评论 2 355

推荐阅读更多精彩内容

  •   一个任务通常就是一个程序,每个运行中的程序就是一个进程。当一个程序运行时,内部可能包含了多个顺序执行流,每个顺...
    OmaiMoon阅读 1,677评论 0 12
  • 从哪说起呢? 单纯讲多线程编程真的不知道从哪下嘴。。 不如我直接引用一个最简单的问题,以这个作为切入点好了 在ma...
    Mr_Baymax阅读 2,762评论 1 17
  • 【JAVA 线程】 线程 进程:是一个正在执行中的程序。每一个进程执行都有一个执行顺序。该顺序是一个执行路径,或者...
    Rtia阅读 2,768评论 2 20
  • Java-Review-Note——4.多线程 标签: JavaStudy PS:本来是分开三篇的,后来想想还是整...
    coder_pig阅读 1,653评论 2 17
  • 第一部分 来看一下线程池的框架图,如下: 1、Executor任务提交接口与Executors工具类 Execut...
    压抑的内心阅读 4,266评论 1 24