语言程序设计第九章 ppt课件

上传人:aa****6 文档编号:54838947 上传时间:2018-09-20 格式:PPT 页数:17 大小:120KB
返回 下载 相关 举报
语言程序设计第九章 ppt课件_第1页
第1页 / 共17页
语言程序设计第九章 ppt课件_第2页
第2页 / 共17页
语言程序设计第九章 ppt课件_第3页
第3页 / 共17页
语言程序设计第九章 ppt课件_第4页
第4页 / 共17页
语言程序设计第九章 ppt课件_第5页
第5页 / 共17页
点击查看更多>>
资源描述

《语言程序设计第九章 ppt课件》由会员分享,可在线阅读,更多相关《语言程序设计第九章 ppt课件(17页珍藏版)》请在金锄头文库上搜索。

1、1,Java面向对象程序设计,第9章 多线程,2,本章主要内容,多线程的概念 线程的创建 继承java.lang.Thread类 实现java.lang.Runnable接口 设置线程为后台线程、设置线程的优先级 线程的同步:售票问题 程序块同步 方法同步 线程间的通信:生产者与消费者问题 线程的终止,3,多线程概述,并行编程通常能够显著地提高程序的性能。 多进程:在操作系统中能同时运行多个任务(程序)。 多线程:在同一应用程序(进程)中有多个顺序流同时执行。 线程与进程的区别:每个进程都有自己的一组完整的变量,而线程则共享相同的数据。 一个运行中的Java程序是一个进程且至少包含一个线程,该

2、线程也称为主线程。,4,Java中使用多线程,通常有两种建立线程的方法: 继承java.lang.Thread类 实现java.lang.Runnable接口,Runnable接口 public interface Runnablepublic void run( ); /线程体 ,Thread类 public class Thread implements Runnable public void run( ) ; /线程体public void start( ) ; /启动线程 ,5,继承Thread类实现多线程,Thread类的构造方法: Thread() Thread(Runnable

3、 target) Thread(String name) 常用实例方法:static Thread currentThread() String getName() int getPriority() Thread.State getState() void interrupt() void run() void setDaemon(boolean on) void start() static void sleep(long millis) static void yield(),演示继承Thread类创建线程,6,继承Thread类实现多线程,设置后台线程(守护线程): setDaemon

4、(true) 当 Java 虚拟机启动时,通常都会有单个非守护线程(它通常会调用某个指定类的 main 方法)。Java 虚拟机会继续执行线程,直到下列任一情况出现时为止: 调用了 Runtime 类的 exit 方法,并且安全管理器允许退出操作发生。 非守护线程的所有线程都已停止运行。 暂停线程: yield(),演示线程暂停和后台线程,7,继承Thread类实现多线程,线程的优先级 每个线程都维护一个优先级的属性,该属性代表了该线程在程序中的重要程度,Java虚拟机将选择优先级最高的线程进入运行状态。 Thread类中提供了一些常量来表示某些优先级,Thread.MIN_PRIORITY表

5、示最低优先级,Thread.MAX_PRIORITY表示最高优先级,Thread.NORM_PRIORITY表示普通优先级,默认情况下,线程的优先级是普通优先级。 除了这三个优先级,Java一共支持10个优先级 。 通过Thread.setPriority( )和Thread.getPriority( )对线程的优先级进行修改与读取 。,演示设置线程优先级,8,实现Runnable接口实现多线程,通过实现Runnable接口来实现线程,需要以下几步: (1)编写类,声明要实现Runnable接口:public class SimpleThread implements Runnable (2)

6、实现线程体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类,就不能

7、继承其他类。 实现Runnable接口的线程可以共享同一资源,例如:,演示启动多个线程共享同一资源,10,多线程实例售票系统,public void run() throws InterruptedException while(true) if (tickets = 0) return;Thread.sleep(1000); /利用线程休眠模拟卖票的时间System.out.println(Thread.currentThread().getName() + “(“ + tickets- + “)“); ,存在问题:当卖最后一张票时,多个线程由于时间片轮换有可能均执行到输出语句,因此,出现卖

8、出第0、-1、-2张票的现象。,演示实现多线程售票系统存在问题,11,线程的同步,为了解决资源共享问题,使用加锁机制,即每一时刻只能有一个线程对共享资源进行读写,就像上了一把锁,只有拥有钥匙的线程才能访问。当线程不再访问共享资源时,再把钥匙交出,由其它想访问该资源的线程竞争访问权。这种对共享资源加以控制的方法,称为同步。 Java语言为了解决同步问题,提供了一个关键字synchronized。这个关键字有两种使用方式:程序块同步和对方法同步。,演示线程同步,12,线程间通信,线程间的通信机制,Java线程之间通信是通过wait( )、notify( )以及notifyAll( )来实现的。,1

9、3,生产者与消费者问题,【例9.6】生产中消费者问题对线程间通信做具体的介绍。系统由生产者线程、消费者线程以及一个共享缓冲区组成,其中: 1. 生产者不断写入,直到共享缓冲区满为止,一旦共享缓冲区有空间,生产者继续写入; 2. 消费者不断读出,直到共享缓冲区为空,一旦共享缓冲区有内容,消费者继续读出; 3. 共享缓冲器内部空间为N(本例设N=1),任一时刻只能有一个线程对缓冲区操作。,演示线程间通信,14,线程的终止,正常退出 一般在写线程体run( )方法的时候,提倡使用无限循环的方式,然后在循环内部通过一个boolean型标记控制循环的停止。 外部中断线程 当线程使用了sleep( )方法

10、或者因为某些方法如wait( )方法的调用而进入阻塞状态,不能自己中断,此时又需要中断该线程,这是可以使用Thread类中的interrupt( )方法使线程中断,但程序会抛出InterruptedException异常。,15,使用Executors创建线程池,Java从1.5版本开始提供Executor。Executor是一个接口,实现此接口的子类作为一个辅助类,能够执行已提交的具有Runnable接口的任务对象。该接口为线程提供一种将任务提交与每个任务将如何运行的机制(包括线程使用的细节、调度等)分离开来的方法。 接口ExecutorService继承了Executor,是一个使用更加广

11、泛的接口。 为了获得一个ExecutorService类型的实例,需要使用Executors工厂类。,16,使用Executors创建线程池,【例9.7】修改例9.6生产者消费者问题,利用Executors建立一个线程池并启动多个线程。为了实现本例,首先需要已经实现Runnable接口的线程体,例9.6中的Producer和Consumer已经符合要求,只需要修改Main,利用Executors来启动多个线程即可。,import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; public

12、 class Main public static void main(String args) /建立线程池ExecutorService exec = Executors.newCachedThreadPool( ); Queue q = new Queue( );exec.execute(new Producer(q); /执行生产者线程exec.execute(new Consumer(q); /执行消费者线程exec.shutdown( ); /不再接收新的线程 ,17,总结,多线程的概念 线程的创建 设置线程为后台线程、设置线程的优先级 线程的同步:售票问题 线程间的通信:生产者与消费者问题 线程的终止,

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 大杂烩/其它

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号