文档详情

java语言程序设计第九章文件材料.ppt

发布:2018-02-19约1.65万字共17页下载文档
文本预览下载声明
* * 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建立一个线程池并启动多个线程。为
显示全部
相似文档