- 1、本文档共17页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
* * 1 Java面向对象程序设计 第9章 多线程 2 本章主要内容 多线程的概念 线程的创建 继承java.lang.Thread类 实现java.lang.Runnable接口 设置线程为后台线程、设置线程的优先级 线程的同步:售票问题 程序块同步 方法同步 线程间的通信:生产者与消费者问题 线程的终止 6 继承Thread类实现多线程 设置后台线程(守护线程): setDaemon(true) 当 Java 虚拟机启动时,通常都会有单个非守护线程(它通常会调用某个指定类的 main 方法)。Java 虚拟机会继续执行线程,直到下列任一情况出现时为止: 调用了 Runtime 类的 exit 方法,并且安全管理器允许退出操作发生。 非守护线程的所有线程都已停止运行。 暂停线程: yield() 演示线程暂停和后台线程 7 继承Thread类实现多线程 线程的优先级 每个线程都维护一个优先级的属性,该属性代表了该线程在程序中的重要程度,Java虚拟机将选择优先级最高的线程进入运行状态。 Thread类中提供了一些常量来表示某些优先级,Thread.MIN_PRIORITY表示最低优先级,Thread.MAX_PRIORITY表示最高优先级,Thread.NORM_PRIORITY表示普通优先级,默认情况下,线程的优先级是普通优先级。 除了这三个优先级,Java一共支持10个优先级 。 通过Thread.setPriority( )和Thread.getPriority( )对线程的优先级进行修改与读取 。 演示设置线程优先级 8 实现Runnable接口实现多线程 通过实现Runnable接口来实现线程,需要以下几步: (1)编写类,声明要实现Runnable接口: public class SimpleThread implements Runnable{} (2)实现线程体run( )方法,这里的代码是核心代码,run方法结束意味着线程结束: public void run( ){...} (3)利用Thread其它的构造方法来构造线程对象,此时线程并没有执行: SimpleThread st = new SimpleThread ( ); Thread t = new Thread(st); //st即为线程对象 (4)调用线程对象的start( )方法,启动线程: t.start( ); 演示实现Runnable接口实现多线程 9 实现多线程 应尽量采用实现Runnable接口方式实现多线程,原因主要有: Java单一继承机制,如果线程类继承了Thread类,就不能继承其他类。 实现Runnable接口的线程可以共享同一资源,例如: 演示启动多个线程共享同一资源 10 多线程实例——售票系统 public void run() throws InterruptedException { while(true) { if (tickets = 0) { return; } Thread.sleep(1000); //利用线程休眠模拟卖票的时间 System.out.println(Thread.currentThread().getName() + ( + tickets-- + )); } } 存在问题:当卖最后一张票时,多个线程由于时间片轮换有可能均执行到输出语句,因此,出现卖出第0、-1、-2张票的现象。 演示实现多线程售票系统存在问题 11 线程的同步 为了解决资源共享问题,使用加锁机制,即每一时刻只能有一个线程对共享资源进行读写,就像上了一把锁,只有拥有钥匙的线程才能访问。当线程不再访问共享资源时,再把钥匙交出,由其它想访问该资源的线程竞争访问权。这种对共享资源加以控制的方法,称为同步。 Java语言为了解决同步问题,提供了一个关键字synchronized。这个关键字有两种使用方式:程序块同步和对方法同步。 演示线程同步 12 线程间通信 线程间的通信机制,Java线程之间通信是通过wait( )、notify( )以及notifyAll( )来实现的。 方法 说明 wait( ) 告诉当前线程放弃同步锁并进入睡眠状态(进入等待队列),直到其他线程进入同一个同步锁并调用notify为止。 notify( ) 将从该同步锁的等待队列中删除一个任意选择的线程,这个线程将再次成为可运行的线程。 notifyAll( ) 将从该同步锁的等待队列中删除所有等待的线程,这些线程将成为可运行的线程。 16 使用Executors创建线程池 【例9.7】修改例9.6生产者消费者问题,利用Executors建立一个线程池并启动多个线程。为
您可能关注的文档
- ConfiguringCiscoEasyVPNandEasyVPNServerUsingSDM文件材料.ppt
- ConfiguringCiscoIOSIPS文件材料教学稿件.ppt
- ConfiguringLayerRedundancywithVRRPandGLBP文件材料.ppt
- ConfiguringLinkAggregationwithEtherChannel文件材料.ppt
- ConfiguringOSPFRouting文件材料.ppt
- ConfiguringWFQ文件材料教学稿件.ppt
- COPD定义发病机理分级及诊断文件材料.ppt
- copd防治指南文件材料教学稿件.ppt
- copd护理查房(二)文件材料教学稿件.ppt
- copd护理查房(九)文件材料教学稿件.ppt
文档评论(0)