1 多线程技术基础.pdf

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

多线程技术基础 北京理工大学计算机学院 金旭亮 多任务环境中的应用程序 2013/11/1 金旭亮Java编程系列(2013版) 2 进程中的线程 线程是可以并行执行的代码片断,线程之间可以共享数据。 2013/11/1 金旭亮Java编程系列(2013版) 3 进程 vs 线程 • 多个进程的内部数据和状态都是完全独立的,而 多线程可以共享进程所拥有的内存空间中的同一 区域以及系统资源,有可能相互影响。 • 线程本身运行所需的环境比较简单,通常只包括 寄存器及堆栈,切换速度比进程要快得多。 • 进程是操作系统分配内存及其他系统资源的基本 单元,线程是操作系统分配CPU的基本单元。 • 在开发中应用多线程技术的主要目的是“最大限 度地利用CPU资源”。比如当某一线程的处理不 需要占用CPU时,就会让给其他线程使用。 2013/11/1 金旭亮Java编程系列(2013版) 4 多任务与多线程 • 所有现代的操作系统(甚至包括手机这样功能较 弱的平台)都支持多任务处理。 • 多任务处理有两种主要类型:基于进程与基于线 程。 任务管理器可以列出 当前正在运行的所有 进程。 2013/11/1 金旭亮Java编程系列(2013版) 5 线程的运行 • 操作系统使用“时间片”来给线程分配CPU 线程 线程 线程 CPU 线程 线程 线程 2013/11/1 金旭亮Java编程系列(2013版) 6 Java线程优先级(Priority) • Java thread priority – Priority in range 1-10 ,默认值为5。 – 线程创建时,子线程继承父线程的优先级 – 线程创建完毕后,可以通过调用setPeriority 方法改变优先级。 • 操作系统线程调度,根据优先级进行 – 非抢占调度:英国的绅士风度,java 中使用 Thread类的yield()方法实现 – 抢占时间片调度:讲究公平 2013/11/1 金旭亮Java编程系列(2013版) 7 Java线程的6种状态 2013/11/1 金旭亮Java编程系列(2013版) 8 JDK为开发多线程的Java应用程序提供了强大的支持 以多线程方式运行代码 2013/11/1 金旭亮Java编程系列(2013版)

文档评论(0)

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

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

版权声明书
用户编号:7014141164000003

1亿VIP精品文档

相关文档