文档详情

第十五章--线程及多线.ppt

发布:2016-12-18约5.35千字共23页下载文档
文本预览下载声明
多线程 多线程编程的含义是将程序任务分成几个并行的子任务,常用于网络编程中。 多线程是与单线程比较而言的 普通的Windows采用单线程程序结构,其工作原理是:主程序有一个消息循环,不断从消息队列中读入消息来决定下一步所要干的事情,一般是针对一个函数,只有等这个函数执行完之后,主程序才能接收另外的消息来执行。 在执行这个子函数过程中你什么也不能干,但往往读网络数据和等待用户输入有很多时间处于等待状态,多线程利用这个特点将任务分成多个并发任务后,就可以解决这个问题 多线程的好处 多线程的优点 多线程使系统的空转时间最少,提高CPU利用率 共享资源,不浪费内存。 线程间的信息传递容易。 线程控制灵活,可在程序中自由调度。 如何实现多线程? Java中实现多线程的类有两种方法: 扩展java.lang.Thread类,覆盖Thread类的run方法。 生成实现java.lang.Runnable接口的类并将其它的实例与java.lang.Thread实例相关联。 Thread类是负责向其它类提供线程支持的最主要的类,要使用一个类具有线程功能,在Java中只要简单地从Thread类派生一个子类就可以了。 多线程举例—Thread类 class ThreadDemo1{ public static void main(String args[]){ MyThread t = new MyThread (); t.start(); while(true){ System.out.println(main thread is running); } } } class MyThread extends Thread { public void run(){ while(true){ System.out.println(Thread.currentThread().getName()+ is running); } } } 线程的四种状态 新状态:线程已被创建但尚未执行(start() 尚未被调用)。 可执行状态:线程可以执行,虽然不一定正在执行。CPU 时间随时可能被分配给该线程,从而使得它执行。 死亡状态:正常情况下 run() 返回使得线程死亡。调用 stop()或 destroy() 亦有同样效果,但是不被推荐,前者会产生异常,后者是强制终止,不会释放锁。 阻塞状态:线程不会被分配 CPU 时间,无法执行。 两种实现多线程方法的比较 class MyThread extends Thread { private int tickets=10; public void run() {while(true) {if(tickets0) System.out.println(Thread.currentThread().getName()+is salling ticket+tickets--); } } } class Test { public static void main(String [] args) { new MyThread().start(); new MyThread().start(); new MyThread().start(); new MyThread().start(); } } 两种实现多线程方法的比较 class MyThread implements Runnable {private int tickets=100; public void run() {while(true) {if(tickets0) System.out.println(Thread.currentThread().getName()+is salling ticket+tickets--); } } } class Test {public static void main(String [] args) { MyThread mt=new MyThread(); new Thread(mt).start(); new Thread(mt).start(); new Thread(mt).start(); new Thread(mt).start(); } } 两种实现多线程方法的比较 使用Runnable接口创建多线程的优点: 同一个Runnable对象可以传递给多个线程,可以实现资源共享,所以适合多个相同程序代码的线程去处理同一资源的情况 可以避免由于Java的单继承带来的局限 有利于程序的健壮性,代码能被多个线程共享,代码与数据是独立的 线程的优先级 线程在优先级代表该线程的重要程度 线程的优先指当有多个线程同时处于可执行状态并
显示全部
相似文档