第7章Java多线程机制.ppt

  1. 1、本文档共84页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第7章Java多线程机制

Java多线程机制 多线程程序设计的意义 生命周期 线程类的主要方法 线程编程的方式 守护线程 线程同步概念 线程死锁 线程的协调与通讯 Java语言的一个重要功能特点就是内置对多线程的支持,它使得编程人员可以很方便地开发出具有多线程功能,能同时处理多个任务的功能强大的应用程序,方便地实现任务的并发处理。 1 程序 - 进程 - 线程 程序是为完成特定任务、用某种语言编写的一组指令的集合。指一段静态的代码。 进程是程序的一次动态执行过程,是系统进行调度和资源分配的一个独立单位。它对应了从代码加载、执行至执行完毕的一个完整过程,这个过程也是进程本身从产生、发展至消亡的过程。 基本概念之一:进程 进程是正在运行的一个程序 程序:静态对象--进程:动态过程 操作系统为每个进程分配一段内存空间, 包括:代码、数据以及堆栈等资源 多任务的操作系统(OS)中,进程切换对 CPU资源消耗较大 例如你的机器装了一个QQ程序,但是同时允许两个帐号登陆,那此时有两个QQ进程运行。 线程 线程是比进程更小的执行单位,一个进程在其执行过程中,可以产生多个线程,形成多条执行线索,每条线索,即每个线程也有它自身的产生、存在和消亡的过程,是一个动态的概念。 线程的特点 线程不能独立存在,必须存在于进程中,各线程间共享进程空间的数据。 线程 — 线程创建、销毁和切换的负荷远小于进程,又称为轻量级进程(lightweight process)。 进程与线程的关系 由谁管理? 线程由程序负责管理,而进程由操作系统调度。 线程依附于进程 线程依附于进程的上下文环境中,随进程或父线程执行后启动。 地址空间 多个线程使用相同的地址空间,因此线程之间的通信非常方便。 而进程之间使用不同的地址空间,可以单独执行。 基本概念之二:多线程 多线程是指同时存在几个执行体,按几条不 同的执行线索共同工作的情况。 多线程实现单个进程中的并发计算。 各线程间共享进程空间的数据,并利用这些 共享单元来实现数据交换、实时通信与必要 的同步操作。 多线程的程序能更好地表述和解决现实世界 的具体问题,是计算机应用开发和程序设计 的一个必然发展趋势。 例如你上QQ后可以给甲传文件,给乙视频聊天。那此时该QQ进程管理了两个线程。分别负责传文件和视频聊天。 进程与多线程 线程的调度 调度策略 时间片 抢占式:高优先级的线程抢占CPU Java的调度方法 同优先级线程组成先进先出队列,使用时间片策略 对高优先级,使用优先调度的抢占式策略 多线程程序设计是并发程序设计的一种,各个线程之间是并行执行的,当我们需要在一个程序当中同时执行几段代码时,就需要用到多线程来实现。 每个application Java程序都有一个隐含的主线程。 Java应用程序总是从主类的main方法开始执行。当JVM加载代码,发现main方法之后,就会启动一个线程,这个线程称作“主线程”,该线程负责执行main方法。 如果main方法中没有创建其他的线程,那么当main方法执行完最后一个语句,即main方法返回时,JVM就会结束我们的Java应用程序。 如果main方法中又创建了其他线程,那么JVM就要在主线程和其他线程之间轮流切换,保证每个线程都有机会使用CPU资源,main方法即使执行完最后的语句,JVM也不会结束我们的程序,JVM一直要等到程序中的所有线程都结束之后,才结束我们的Java应用程序 2 线程的生命周期 要想实现线程,必须在主线程中创建新的线程对象。Java语言使用Thread类及其子类的对象来表示线程,在它的一个完整的生命周期中通常要经历如下的五种状态: 2 线程的生命周期 新建: 当一个Thread类或其子类的对象被声明并创建时,新生的线程对象处于新建状态 就绪:处于新建状态的线程被启动后,将进入线程队列等待CPU时间片,此时它已具备了运行的条件 运行:当就绪的线程被调度并获得处理器资源时,便进入运行状态, run()方法定义了线程的操作和功能 阻塞:在某种特殊情况下,被人为挂起或执行输入输出操作时,让出CPU并临时中止自己的执行,进入阻塞状态 死亡:线程完成了它的全部工作或线程被提前强制性地中止 stop()或destroy() 线程的生命周期 线程的生命周期(续) Newborn:线程已创建,但尚未执行 Runnable:(就绪) 线程已被调度,按优先级和先到先服务原则在 队列中排队等待CPU时间片资源 Runnnig:正在运行 Blocked:(阻塞) 因某事件或睡眠而被暂时性地挂起 Dead:正常/强行中断,退出运行状态 线程状态 3 Java对多线程的支

文档评论(0)

dajuhyy + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档