立即注册 登录
一牛网 返回首页

康草根的个人空间 http://bbs.16rd.com/?42843 [收藏] [复制] [RSS]

日志

Java多线程由易到难

热度 4已有 4104 次阅读2016-11-7 16:57 |个人分类:Java并发学习|系统分类:基础知识

线程可以驱动任务,因此你需要一种描述任务的方式,这可以由Runnable接口来提供。要想定义任务,只需实现Runnable接口并编写run方法,使得该任务可以执行你的命令。

这里写图片描述

将Runnable对象转变为工作任务的传统方式是把它提交给一个Thread构造器,&nBSP;
Thread构造器只需要一个Runnable对象。调用Thread对象的start()方法为该线程执行必需的初始化操作, 
然后调用Runnable的run()方法,以便在这个新线程中启动该任务。因为main()方法和LiftOff.run()是由不同 
的线程执行的,因此程序同时运行两个方法。 
这里写图片描述

线程调度没有顺序的,由CPU决定。 
这里写图片描述

接下来通过Java.util.concurrent包中的执行器(Executor)将为你管理Thread对象,从而简化了并发编程。

1:CachedThreadPool首先会按照需要创建足够多的线程来执行任务(Task)。随着程序执行的过程,有的线程执行完了任务,可以被重新循环使用时,才不再创建新的线程来执行任务 
这里写图片描述
对shutdown()方法的调用可以防止新任务被提交给这个Executor,当前线程(即驱动main()的线程)将 
继续运行在shutdown()被调用之前提交的所有任务。这个程序将在Executor中的所有任务完成之后尽快退出。

2:FixedThreadPool模式会使用一个优先固定数目的线程来处理若干数目的任务。规定数目的线程处理所有任务,一旦有线程处理完了任务就会被用来处理新的任务(如果有的话)。 
这里写图片描述
最好把3换成Runtime.getRuntime().availableProcessors(),这样能更大程度利用你的电脑CPU处理。

3:SingleThreadExecutor就像是线程数量为1的FixedThreadPool。如果多个任务被提交给SingleThreadExecutor的话,那么这些任务会被保存在一个队列中,并且会按照任务提交的顺序,一个先执行完成再执行另外一个线程。SingleThreadExecutor模式可以保证只有一个任务会被执行。这种特点可以被用来处理共享资源的问题而不需要考虑同步的问题。 
这里写图片描述


路过

鸡蛋
1

鲜花

握手

雷人

刚表态过的朋友 (1 人)

全部作者的其他最新日志

发表评论 评论 (4 个评论)

回复 lz_kwok 2016-11-8 08:53
成功可能需要十年,失败只要一天!
回复 Mr刘 2016-11-15 10:40
专业开发硬件,软件,手机APP,云服务,研发工程师有300多名。希望有合作的机会,联系电话18138298019  刘经理  
回复 lz_kwok 2016-11-16 08:31
查看内容
全部资讯 移动终端IT业界物联网机器人无人机智能硬件VR/AR创业ClubIC资讯
北漂IT男 创业遇8坑:千万融资一年烧光!
回复 Galen 2016-11-16 15:50
可以  学的不错

facelist

您需要登录后才可以评论 登录 | 立即注册

联系我们|小黑屋