[工学]jaa学习课件10.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文档。上传文档
查看更多
[工学]jaa学习课件10

第 11 章 多线程程序设计 山东理工大学计算机学院 周雪芹 二O一O年十一月 操作系统中的进程概念(process) 进程﹕具有独立功能的可并发执行的程序关于某个数据集合上的一次执行过程,是操作系统进行资源分配和保护的基本单位。 进程的属性: 结构性:(构成)程序块、数据块、进程控制块(描述和记录进程的动态变化过程) 共享性:同一程序同时运行于不同数据集上构成不同的进程,即多个不同进程可以共享相同的程序。 动态性:进程是程序在数据集上的一次执行过程,有生命周期 程序是一组有序指令序列,是静态概念,作为一种系统资源永久存在。 独立性:既是系统资源分配和保护的基本单位,也是系统调度的独立单位(单线程进程)。每个进程以各自独立速度在CPU上推进。 并发性(concurrency): 制约性:并发进程在执行的关键点上需要等待或互通消息 进程的状态 就绪态、运行态、阻塞态 操作系统中的线程概念(thread) 线程机制的基本思路: 把独立分配资源和被调度分派执行功能分离,分别由进程和线程完成。 线程﹕比进程更小、能独立运行的基本单位。 是进程的组成部分,每个进程允许包含多个并发执行的线程,它们共享进程获得的主存空间和资源,但不拥有。 线程的特性: 并发性、共享性、动态性 线程的状态: 线程的调度 线程调度:多个线程处于就绪态等候CPU,对于单处理器,任一时刻只有一个线程能够占用处理器运行。按照什么原则选定就绪队列中的哪个线程获得处理器资源即线程调度 线程调度中执行分配处理器的程序称为分派程序(dispatcher) 执行十分频繁、操作系统的核心 线程调度策略(剥夺方式) 剥夺原则: 高优先级线程剥夺低优先级线程,同优先级先到先服务 当运行线程时间结束后 操作系统和其他软件对 进程与线程的支持 诸多操作系统支持多线程进程的并发处理机制,使多个程序能并发执行: 改善资源使用率,提高系统效率 减少程序并发时所付出的时空开销,并发粒度更细,并发性更好 线程不仅在操作系统中,程序设计语言、数据库管理系统、一些应用软件,也支持线程来改善系统和应用程序的性能。 并发多线程程序设计: 在一个进程中包含多个并行执行的控制流 本章总体纲要 11.1 编写线程程序(P385) 11.1.1 通过Thread的子类构造线程(P385) 11.1.2 通过接口Runnable构造线程(P388) 11.1.3 后台线程(P391) 11.1.4 线程组(P394) 11.2 线程的生命周期(P396) 11.3 多线程的同步处理(P399) 11.4 多线程的同步问题(P425) JAVA支持多线程 JAVA在语言级别上支持多线程的并发程序设计,提供: java.lang.Thread类 java.lang.Runnable接口 用于创建、管理、控制线程对象 Runable接口 只声明了一个方法: public interface Runnable { public abstract void run(); } 本章总体纲要 11.1 编写线程程序(P385) 11.1.1 通过Thread的子类构造线程(P385) 11.1.2 通过接口Runnable构造线程(P388) 11.1.3 后台线程(P391) 11.1.4 线程组(P394) 11.2 线程的生命周期(P396) 11.3 多线程的同步处理(P399) 11.4 多线程的同步问题(P425) 通过类Thread构造线程类 线程程序执行代码 public void run( ) 启动线程 public void start( ) Thread类 构造方法: 常用方法 final String getName() //返回线程名称 final void setName(String name) //设置线程名称 static int activeCount() //返回当前活动线程个数 static Thread currentThread() //返回当前执行线程对象 String toString() //返回线程的字符串(名字、优先级、线程组) 继承Thread类实现奇/偶数序列的线程并发执行 public class NumberThread extends Thread { private int k; public NumberThread(String name,int k) { super(name); this.k=k; } public NumberThread(String name)

文档评论(0)

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

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

1亿VIP精品文档

相关文档