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