第八章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文档。上传文档
查看更多
8.1 线程的概念 8.2 Java中多线程的编程 8.3 线程的同步与死锁 8.1线程的概念 1.程序、进程和线程 1)程序是为完成特定任务、用某种语言编写的一组指令的集合。指一段静态的代码。 2)进程是程序的一次执行过程,是系统进行调度和资源分配的一个独立单位。 3)进程中的一小段程序代码称为线程。 2.线程的主要特点: 1) 不能以一个文件名的方式独立存在在 磁盘中;不能单独执行,只有在进程启动后才可启动;各线程间共享进程空间的数据(代码与数据). 2)线程是比进程更小一级的执行单元。 3)一个进程在其执行过程中,可以产生多个线程,形成多条执行线索。 4)每个线程也有它自身的产生、存在和消亡的过程,也是一个动态的概念。 5)一个线程有它自己的入口和出口,以及一个顺序执行的序列 6)线程不能独立存在,必须存在于进程中,线程 — 线程创建、销毁和切换的负荷远小于进程,又称为轻量级进程(lightweight process)。系统负担小,主要是CPU的分配。 3.进程 进程是正在运行的一个程序 程序:静态对象-- 进程:动态过程操作系统为每个进程分配一段内存空间,包括:代码、数据以及堆栈等资源多任务的操作系统(OS)中,进程切换对 CPU资源消耗较大 4.多线程 1)多线程是指同时存在几个执行体,按几条不同的执行线索共同工作的情况。 2)多线程实现单个进程中的并发计算。 3)各线程间共享进程空间的数据,并利用这些共享单元来实现数据交换、实时通信与必要的同步操作。 4)多线程的程序能更好地表述和解决现实世界的具体问题,是计算机应用开发和程序设计的一个必然发展趋势。 进程与多线程 5.线程的调度 调度策略 时间片 抢占式:高优先级的线程抢占CPU Java的调度方法 同优先级线程组成先进先出队列,使用时间片策略 对高优先级,使用优先调度的抢占式策略 6.Java与多线程 1)Java语言的一个重要功能特点:就是内置对多线程的支持,它使得编程人员可以很方便地开发出具有多线程功能,能同时处理多个任 务的功能强大的应用程序。 2)每个Java程序都有一个隐含的主线程 每个Java程序都有一个主线程,对于APPLICATION程序,主线程是main()函数执行的线索; 对于Applet程序指挥浏览器加载并执行Java小程序,要想实现多线程,必须在主线程中创建新的线程对象。 3)线程的用途:利用它可以完成重复性的工作(如实现动画、声音等的播放);从事一次性较费时的初始化工作(如网络连接、声音数据文件的加载,但对图像文件 *.gif、*.jpeg在java中自动地在后台载入、因而可不必设计图像载入的线程);并行的执行效果(一个进程多个线程)。 6.线程的生命周期 要想实现线程,必须在主线程中创建新的线程对象。Java语言使用Thread类及其子类的对象来表示线程,在它的一个完整的生命周期中通常要经历如下的五种状态: 1)新建: 当一个Thread类或其子类的对象被声明并创建时,新生的线程对象处于新建状态 2)就绪:处于新建状态的线程被启动后,将进入线程队列等待CPU时间片,此时它已具备了运行的条件 3)运行:当就绪的线程被调度并获得处理器资源时,便进入运行状态, run()方法定义了线程的操作和功能 4)阻塞:在某种特殊情况下,被人为挂起或执行输入输出操作时,让出CPU并临时中止自己的执行,进入阻塞状态 5)死亡:线程完成了它的全部工作或线程被提前强制性地中止 stop()或destroy() 线程死亡不具有继续运行能力 线程死亡有两个原因: ___正常执行的线程完成它的全部工作,即执行完run()方法的最后一句并退出 ___线程被强制终止,如stop()方法、 destroy()方法 Java提供对多线程的支持 Thread类 start( ), stop( ), run( ) Runnable 接口 实现多线程的两种编程方法 继承 Thread 类 实现 Runnable 接口 Thread类 Thread类综合了Java程序中一个线程需要拥有的属性和方法 当生成一个Thread类的对象后,一个新的线程诞生了。 每个线程都是通过目标对象的方法run()来完成其操作的。方法run() 称为线程体(线程方法)。 提供线程体的目标对象是在初始化一个线程时指明的。 任何实现了Runnable接口(实现run()方法)的类实例都可以作为线程的目标对象。 方法之一:继承Thread类 Thread类的重要方法:run( ) 定义线程的具体操作 系统调度此线程时自动执行 初始时无具体操作内容 如何编程呢? Thread类在java.lang

文档评论(0)

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

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

1亿VIP精品文档

相关文档