- 1、本文档共44页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
java多线程编程 PPT
三、线程的同步与死锁 对于一个多线程程序,虽然把一个方法声明成synchronized是一种解决并发访问问题的很简单的途径,但是因为每个线程都必须等待执行线程的同步方法结束直到轮到自己,所以这对程序的性能会造成不良的影响。对于耗时很长才能结束的复杂synchronized方法,该程序的性能损失是非常之大的。为了降低对整个方法进行synchronized声明时它对程序性能所造成的影响,可以使用同步synchronized语句来代替同步方法。当程序块执行到方法中访问共享对象的时候,synchronized语句才锁定该对象。因此,在这种方式下,synchronized方法在整个执行过程中对象的锁并不总是保持有效,只有在synchronized语句被执行时对象的锁才有效,这样程序的效率有可能会更高一些。 第八章 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()方法可以改变一个线程的优先级别。 一、线程的概念 一个线程的生命周期分为生成、运行、等待、终止等阶段,各阶段及状态间的转换条件具体如图所示 死亡 Start 睡眠 挂起 等待 就绪 运行RUN notify I/O完成 定时到 Resume Stop Wait 请求I/O Sleep Suspend 创建 阻塞 一、线程的概念 说明:控制一个线程生命周期最常用的方法有start()方法(启动一个线程)、run()方法(定义线程动作)、sleep()方法(使线程睡眠一段时间)、suspend()方法(使线程挂起)、resume()方法(恢复挂起的线程)、yield()方法(把线程移到队列的尾部)、stop()方法(结束线程生命周期并执行清理工作)、destroy()方法(结束线程生命周期但不做清理工作)、wait()方法(使一个线程进入等待状态)、notify()方法(将等待线程激活)。 一、线程的概念 (1)start():线程调用该方法启动一个线程,使之从新建状态进入就绪队列,一旦获得CPU就可以脱离创建它的主线程独立开
您可能关注的文档
最近下载
- 京剧的服装课件.ppt VIP
- 保证供货周期的组织方案和人力资源安排.doc VIP
- 乌有先生历险记(原文,练习,注释,翻译)解读.doc
- 红色经典故事PPT课件.pptx VIP
- (人教版2024)生物七上2.2.1 无脊椎动物(新教材).pptx
- 2023-2024学年江西省上饶市余干县八年级上期中物理试卷附答案解析.pdf
- 西北师范大学教育学理论与实践期末试卷.doc VIP
- 2023年成都信息工程大学数据科学与大数据技术专业《数据结构与算法》科目期末试卷B(有答案).docx VIP
- 河北省衡水中学2024-2025学年高三上学期第一次综合素养测评数学试题(原卷版).docx
- 数据结构(用面向对象方法与C++语言描述)第二版.pdf VIP
文档评论(0)