[Java多线程编程.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
[Java多线程编程

第八章 Java语言多线程编程 一、线程的概念 二、线程的实现方法 三、线程的同步与死锁 四、多线程程序实例 一、线程的概念 进程与线程 进程是指可执行程序并存放在计算机存储器空间的一个指令序列,它是一个动态执行的过程。进程是计算机多任务操作系统为任务分配资源的最小单位,每个进程都应该有自己的内存空间。 线程同进程一样,也是一个动态的概念和一个动态的执行过程,但是线程比进程的内涵要小一个等级,一般一个进程(应用程序)包含一个或多个线程,线程需要在进程的内存地址空间中运行,是多任务操作系统用于分配计算机CPU时间片的最小单位。 一、线程的概念 一个Java多线程程序在Java虚拟机中执行时,每一个线程的执行过程是由Java执行系统的线程调度来控制的,Java语言多线程程序自身是不能控制每个线程执行顺序的。在目前的多任务操作系统中,当一个单一线程被启动以后,它可以被挂起来,被挂起的线程程序代码并不从计算机内存中清除,只是暂时不让它执行了,在内存中被挂起的线程还可以重新被恢复执行,以便保证实现多任务被同时处理。多任务操作系统在任何时间都可以停止或终止线程,被终止的线程程序代码将被从计算机内存中清除,被终止的线程是不能再重新恢复执行的。 一、线程的概念 线程调度与优先级 在CPU上以某种次序执行多个线程称为调度,调度使JVM对运行的多个线程进行协调,以避免多个线程争用有限的系统资源而导致系统死机或崩溃。 为控制线程的协调运行,Java定义了线程监视器来监控系统中处于就绪状态的所有线程,线程调度采用“抢占式”策略,按照线程的优先级别选择线程获得处理器。 线程优先级(Priority)告诉线程监视器该线程的重要性,如果有大量线程被堵塞并等候运行时,线程监视器按线程的优先级别对线程排队,一旦空闲,线程监视器会首先选择运行具有最高优先级的那个线程。当然这并不表示优先级别较低的线程不会运行,即线程不会因为存在优先级而导致死锁。 一、线程的概念 Java将线程的优先级分为10个等级,分别用1~10之间的数字表示,数字越大表明线程的优先级别越高。Thread类中定义了代表线程优先级的三个静态整型数据成员MIN_ PRIORITY、MAX_PRIORITY和NORMAL_PRIORITY,分别对应于线程的最高优先级(10)、最低优先级(1)和普通线程优先级(5)。当创建一个线程对象时,其默认的优先级别是5。一个线程的优先级别可以通过调用Thread类中的getPriority()方法来获得,而通过调用setPriority()方法可以改变一个线程的优先级别。 一、线程的概念 线程的状态与生命周期 每个线程都与生命周期相关联,一个生命周期含有多个可以互相转换的状态,线程从产生到消亡的生命周期中要经历创建、就绪、运行、阻塞和死亡五种状态。通过线程的控制与调度可使线程在这几个状态间转换,每个Java程序中都拥有一个与main方法对应的主线程,必须在主线程中创建新的线程。 (1)创建状态:当一个Thread类或其子类的对象被声明并创建后,该线程对象就处于创建状态。创建状态是线程已经创建但未开始执行的一个特殊状态。处于创建状态的线程只是一个空的线程对象,系统不为它分配资源但有自己的内存空间,通过调用start()方法进入就绪状态。 一、线程的概念 (2)就绪状态:处于就绪状态的线程已经具备运行条件但还未获得时间片,因此进入线程队列,等待系统为其分配CPU。一旦获得CPU,该线程便进入运行状态并自动调用自己的Run()方法。 (3)运行状态:当就绪状态的线程被调度并获得处理器资源时便进入运行状态,这时开始执行run()方法中的代码,直到调用其他方法而终止,或等待某资源而阻塞,或运行完毕而死亡。 (4)堵塞状态:处于运行状态的线程在某些情况下,如执行睡眠方法或等待I/O设备操作时,将让出CPU并暂时终止自己的运行进入阻塞状态。阻塞时线程不能进入就绪队列,只有当引起阻塞的原因消除时,线程才可以转入就绪状态,重新进入线程队列等待调度。 (5)死亡状态:死亡状态是线程生命周期的最后一个阶段,表示线程已经退出运行状态并且不再进入就绪队列。当线程的run()方法结束或由于其它原因被终止后,线程便进入消亡状态。线程的终止分为两种形式:一是自然死亡即线程的run()方法正常结束,二是强制终止线程,如调用destory()或stop()命令终止线程。 一、线程的概念 一个线程的生命周期分为生成、运行、等待、终止等阶段,各阶段及状态间的转换条件

文档评论(0)

wuxinghua828 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档