- 1、本文档共76页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第10章多线程ppt课件
第10章 多线程 学习目标 本章要点 上机练习 习 题 学习目标 在计算机处理任务时,往往需要操作系统同时处理多个任务,这些任务就由操作系统本身和CPU来控制。有时也需要自己创建多个任务来让系统同时完成,这些用户自己定制的任务都是非常小的程序段,称为线程。本章介绍线程的基本概念和多线程技术,详细讲解线程的创建,如何实现多线程,还介绍线程同步、线程死锁和线程调度等控制技术。 本章要点 线程的生命周期 多线程技术 线程的创建和实现多线程 线程的同步和死锁 多线程技术的基本概念 多线程是Java程序的一个重要特征,线程本来是操作系统中的概念,Java将这一概念引入到程序设计语言中,让开发人员利用线程机制编写多线程程序,使系统能够同时运行多个执行体,从而加快程序的响应速度,提高电脑资源的利用率。本节主要介绍多线程机制的一些基本概念。 多线程技术的基本概念 什么是线程 线程的生命周期 多线程技术 什么是线程 线程和进程类似,是一段完成特定功能的代码。线程是程序中单个程序的控制流,也是一个进程内的基本调度单位。线程和进程一样拥有独立的执行控制,并由操作系统负责调度。 什么是线程 同一个进程可以包含多个线程,这些线程共享属于该进程的一块内存空间和一组系统资源,而线程自身的数据通常只有CPU的寄存器数据,以及一个供程序执行时使用的堆栈,系统在产生一个线程,或者在各个线程之间切换时,负荷比进程小得多。 什么是线程 此外,由于线程知识在单个进程的作用域内活动,所以线程之间的通信也比进程简单。线程的实现要依赖操作系统,现在一般操作系统都支持线程技术。 什么是线程 一个或更多的线程构成了一个进程。一个线程或执行上下文由一个虚拟处理机、CPU执行的代码和代码操作的数据3个主要部分组成。 线程执行的主要组成部分 什么是线程 代码可以由多个线程共享,也可以不被共享,这些都和数据是独立的。两个线程如果执行同一个类的实例代码,则它们可以共享相同的代码。 什么是线程 类似地,数据可以由多个线程共享,也可以不被共享,这些都和代码是独立的。两个线程如果共享对一个公共对象的存取,则它们可以共享相同的数据。 什么是线程 在Java编程中,虚拟处理机封装在Thread类的一个实例。构造线程时,代码和数据是由传递给它的构造方法的对象指定的。 线程的生命周期 每个Java程序都有一个默认的主线程,对于Java Applicatin应用程序,主线程就是main方法执行的指令序列,对于Java Applet,主线程指挥浏览器装载并执行Java Applet。 线程在它完整的生命周期中包括新建、就绪、运行、阻塞和死亡5种状态。 线程的生命周期 新建(New):代表线程的对象已经被初始化,但尚未运行run方法。 就绪(Runnable):线程正在运行run方法,但这只说明线程目前处于的状态。如果系统没有能力抽出CPU执行时间给线程,线程就“不执行”,这里的“不执行”不代表“阻塞”或“死亡”。 线程的生命周期 运行(Running):线程获得了CPU资源正在执行任务,将一直运行到结束,除非此时它自动放弃资源或有更加高优先级的线程进入。 线程的生命周期 阻塞(Blcked):线程是可以执行的,但由于某些因素的阻碍处于停滞状态,系统排程器略过了应给线程的CPU执行时间。 死亡(Dead):线程的正式结束方式,run方法执行完毕并返回。 多线程技术 多线程是这样一种机制,它允许在程序中并发执行多个指令流,每个指令流都称为一个线程,线程彼此间互相独立。 多线程技术 线程和进程一样拥有独立的执行控制,由操作系统负责调度,区别在于线程没有独立的存储空间,而是和所属进程中的其它线程共享一个存储空间,这使得线程间的通信比进程简单。 多线程技术 多个线程的执行是并发的,也就是在逻辑上“同时”,而不管是否是物理上的“同时”。如果系统只有一个CPU,那么真正的“同时”是不可能的,但是由于CPU的速度非常快,用户感觉不到其中的区别,因此也不用关心它,只需要设想各个线程是同时执行即可。 多线程技术 多线程和传统的单线程在程序设计上最大的区别在于,由于各个线程的控制流彼此独立,使得各个线程之间的代码是无序执行的。 多线程技术的实现 在了解了线程的基本概念之后,本节将继续深入,介绍如何创建线程,如何实现多线程,线程同步、死锁和调度等等多线程技术。 线程的创建 如何实现多线程 多线程技术的实现 线程同步 线程死锁 线程调度 应用举例——抢硬币 线程的创建 为了创建一个新的线程,必须指明这个线程所要执行的代码,Java是通过类做到这一点的。作为一个面向对象的程序设计语言,Java提供了java.lang.Thread类来进行多线程编程,这个类提供了大量的方
文档评论(0)