进程与线程 (2)优秀课件.ppt
《进程与线程 (2)优秀课件.ppt》由会员分享,可在线阅读,更多相关《进程与线程 (2)优秀课件.ppt(30页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、进程与线程第1页,本讲稿共30页本章内容进程与线程的概念创建子进程线程创建与启动线程组定时器TimerTask线程状态转换线程的交互线程的调度线程同步并发协作-死锁线程池“生产者-消费者-仓储”模型第2页,本讲稿共30页进程和线程现在的操作系统是多任务的,多线程是实现多任务的一种方式。进程是指一个内存中运行的应用程序,每个进程都有自己独立的一块内存空间,一个进程中可以启动多个线程。比如在Windows系统中,一个运行的exe就是一个进程。线程是进程中的执行分支,一个进程可以运行多个线程。进程中的多个线程共享进程的内存。由于CPU执行速度非常快,给人以多个进程“同时”执行的感觉,实际上线程之间是
2、轮换执行的。第3页,本讲稿共30页创建子进程通过Java代码启动多个Java子进程,虽然占用一些系统资源,但会使程序更加稳定,因为新启动的程序是在不同的虚拟机进程中运行的,如果有一个进程发生异常,并不影响其它的子进程。使用Runtime调用子进程程序。使用ProcessBuilder建立子进程。第4页,本讲稿共30页创建线程线程的创建有两种方式:第一种:扩展java.lang.Thread类。第二种:实现java.lang.Runnable接口。重写run()方法。第5页,本讲稿共30页实例化线程如果是扩展如果是扩展java.lang.Threadjava.lang.Thread类的线程,则直
3、接类的线程,则直接newnew即即可。可。如果是实现了如果是实现了java.lang.Runnablejava.lang.Runnable接口的类,则调用接口的类,则调用ThreadThread的构造方法:的构造方法:Thread(Runnable target)Thread(Runnable target)Thread(Runnable target,String name)Thread(Runnable target,String name)Thread(ThreadGroup group,Runnable target)Thread(ThreadGroup group,Runnable
4、target)Thread(ThreadGroup group,Runnable target,Thread(ThreadGroup group,Runnable target,String name)String name)Thread(ThreadGroup group,Runnable target,String Thread(ThreadGroup group,Runnable target,String name,long stackSize)name,long stackSize)分配新的分配新的 Thread Thread 对象,以便将对象,以便将 target target 作
5、为其运行对作为其运行对象,将指定的象,将指定的 name name 作为其名称,作为作为其名称,作为 group group 所引用所引用的线程组的一员,并具有指定的堆栈尺寸。的线程组的一员,并具有指定的堆栈尺寸。第6页,本讲稿共30页启动线程在线程的Thread对象上调用start()方法,而不要直接调用run()或者别的方法。在调用start()方法之后,发生了一系列动作:1、启动新的执行线程(具有新的调用栈);2、该线程从新状态转移到可运行状态;3、当该线程获得机会执行时,其目标run()方法将运行。注意:对Java来说,run()方法没有任何特别之处。像main()方法一样,它只是新线
6、程知道调用的方法名称(和签名)。因此,在Runnable上或者Thread上调用run方法是合法的。但并不启动新的线程。第7页,本讲稿共30页关于线程创建和启动的问题运行中的线程总是有名字的,名字有两个来源,一个是虚拟机自己给的名字,一个是你自己的定的名字。在没有指定线程名字的情况下,虚拟机总会为线程指定名字,并且主线程的名字总是mian,非主线程的名字不确定。线程都可以设置名字,也可以获取线程的名字,连主线程也不例外。获取当前线程的对象的方法是:Thread.currentThread()。一系列线程以某种顺序启动并不意味着将按该顺序执行。对于任何一组启动的线程来说,调度程序不能保证其执行次
7、序,持续时间也无法保证。第8页,本讲稿共30页当线程目标run()方法结束时该线程完成。一旦线程启动,它就永远不能再重新启动。只有一个新的线程可以被启动,并且只能一次。一个可运行的线程或死线程可以被重新启动。线程的调度是JVM的一部分,在一个CPU的机器上上,实际上一次只能运行一个线程。一次只有一个线程栈执行。JVM线程调度程序决定实际运行哪个处于可运行状态的线程。尽管是采用队列形式,事实上,把它称为可运行池而不是可运行队列。尽管我们没有无法控制线程调度程序,但可以通过别的方式来影响线程调度的方式。第9页,本讲稿共30页线程状态转换图第10页,本讲稿共30页关于线程状态转换的几点说明新状态:线
8、程对象已经创建,还没有在其上调用start()方法。可运行状态:当线程有资格运行,但调度程序还没有把它选定为运行线程时线程所处的状态。当start()方法调用时,线程首先进入可运行状态。在线程运行之后或者从阻塞、等待或睡眠状态回来后,也返回到可运行状态。运行状态:线程调度程序从可运行池中选择一个线程作为当前线程时线程所处的状态。这也是线程进入运行状态的唯一一种方式。等待/阻塞/睡眠状态:这是线程有资格运行时它所处的状态。实际上这个三状态组合为一种,其共同点是:线程仍旧是活的,但是当前没有条件运行。换句话说,它是可运行的,但是如果某件事件出现,他可能返回到可运行状态。死亡态:当线程的run()方
9、法完成时就认为它死去。这个线程对象也许是活的,但是,它已经不是一个单独执行的线程。线程一旦死亡,就不能复生。如果在一个死去的线程上调用start()方法,会抛出java.lang.IllegalThreadStateException异常。第11页,本讲稿共30页定时器TimerTaskTimerTask是一种特殊的线程,用来为Timer安排一次执行或重复执行的任务。它实现了Runnable接口,是一个抽象类:public abstract class TimerTask implements RunnableTimerTask本身没有实现run()方法,需要子类来实现它。定时器任务与线程不同
10、,它是定时执行的线程,因此不能够直接使用start()来启动它,而需要使用一个特殊的类Timer来启动它。Timer是一种工具,用来安排在后台线程中执行的任务。第12页,本讲稿共30页阻止线程执行的三个因素IO阻塞睡眠等待IO阻塞是由于线程等待输入输出而交出CPU时间处于等待状态。在此暂不讨论IO阻塞的情况。第13页,本讲稿共30页睡眠Thread.sleep(long millis)和Thread.sleep(long millis,int nanos)静态方法强制当前正在执行的线程休眠(暂停执行),以“减慢线程”。当线程睡眠时,它入睡在某个地方,在苏醒之前不会返回到可运行状态。当睡眠时间到
11、期,则返回到可运行状态。线程睡眠的原因:线程执行太快,或者需要强制进入下一轮,因为Java规范不保证合理的轮换。睡眠的实现,调用静态方法:Thread.sleep(100);/睡眠100毫秒第14页,本讲稿共30页关于睡眠的几点说明线程睡眠是帮助所有线程获得运行机会的最好方法。线程睡眠到期自动苏醒,并返回到可运行状态,不是运行状态。sleep()中指定的时间是线程不会运行的最短时间。因此,sleep()方法不能保证该线程睡眠到期后就开始执行。sleep()是静态方法,只能控制当前正在运行的线程。第15页,本讲稿共30页线程优先级线程总是存在优先级,优先级范围在110之间。JVM线程调度程序是基
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 进程与线程 2优秀课件 进程 线程 优秀 课件
限制150内