搞起一个有意思的..
了解下多线程可以干嘛
?
第一个多线程展示一个有意思的多线程
?
第二个多线程展示怎么轮询每个多线程是否结束
?
第一多线程:
?
package cn.edu.xmu.dm.mt; import java.io.*; //多线程编程 public class MultiThread { public static void main(String args[]) { System.out.println("我是主线程!"); // 下面创建线程实例thread1 ThreadUseExtends thread1 = new ThreadUseExtends(); // 创建thread2时以实现了Runnable接口的THhreadUseRunnable类实例为参数 Thread thread2 = new Thread(new ThreadUseRunnable(), "SecondThread"); thread1.start();// 启动线程thread1使之处于就绪状态 // thread1.setPriority(6);//设置thread1的优先级为6 // 优先级将决定cpu空出时,处于就绪状态的线程谁先占领cpu开始运行 // 优先级范围1到10,MIN_PRIORITY,MAX_PRIORITY,NORM_PAIORITY // 新线程继承创建她的父线程优先级,父线程通常有普通优先级即5NORM_PRIORITY System.out.println("主线程将挂起7秒!"); try { Thread.sleep(7000);// 主线程挂起7秒 } catch (InterruptedException e) { return; } System.out.println("又回到了主线程!"); if (thread1.isAlive()) { thread1.stop();// 如果thread1还存在则杀掉他 System.out.println("thread1休眠过长,主线程杀掉了thread1!"); System.out.println("---------------thread1 kill" + thread1.getValue()); } else{ System.out.println("---------------thread1 stop" + thread1.getValue()); System.out.println("主线程没发现thread1,thread1已醒顺序执行结束了!"); } thread2.start();// 启动thread2 System.out.println("主线程又将挂起7秒!"); try { Thread.sleep(7000);// 主线程挂起7秒 } catch (InterruptedException e) { return; } System.out.println("又回到了主线程!"); if (thread2.isAlive()) { thread2.stop();// 如果thread2还存在则杀掉他 System.out.println("thread2休眠过长,主线程杀掉了thread2!"); } else System.out.println("主线程没发现thread2,thread2已醒顺序执行结束了!"); System.out.println("程序结束按任意键继续!"); try { System.in.read(); } catch (IOException e) { System.out.println(e.toString()); } }// main }// MultiThread class ThreadUseExtends extends Thread // 通过继承Thread类,并实现它的抽象方法run() // 适当时候创建这一Thread子类的实例来实现多线程机制 // 一个线程启动后(也即进入就绪状态)一旦获得CPU将自动调用它的run()方法 { private double value; ThreadUseExtends() { }// 构造函数 public void run() { System.out.println("我是Thread子类的线程实例!"); System.out.println("我将挂起10秒!"); System.out.println("回到主线程,请稍等,刚才主线程挂起可能还没醒过来!"); try { value = 10; sleep(10000);// 挂起5秒 } catch (InterruptedException e) { return; } // 如果该run()方法顺序执行完了,线程将自动结束,而不会被主线程杀掉 // 但如果休眠时间过长,则线程还存活,可能被stop()杀掉 } public double getValue() { return value; } public void setValue(double value) { this.value = value; } } class ThreadUseRunnable implements Runnable // 通过实现Runnable接口中的run()方法,再以这个实现了run()方法的类 // 为参数创建Thread的线程实例 { private double value; // Thread thread2=new Thread(this); // 以这个实现了Runnable接口中run()方法的类为参数创建Thread类的线程实例 ThreadUseRunnable() { }// 构造函数 public void run() { System.out.println("我是Thread类的线程实例并以实现了Runnable接口的类为参数!"); System.out.println("我将挂起1秒!"); System.out.println("回到主线程,请稍等 jn0-120 e20-040 ,刚才主线程挂起可能还没醒过来!"); try { Thread.sleep(1000);// 挂起5秒 value = 1; } catch (InterruptedException e) { return; } // 如果该run()方法顺序执行完了,线程将自动结束,而不会被主线程杀掉 // 但如果休眠时间过长,则线程还存活,可能被stop()杀掉 } public double getValue() { return value; } public void setValue(double value) { this.value = value; } } // 该程序可做的修改如改休眠时间或优先级setPriority()
?package cn.edu.xmu.dm.mt;
?
import java.io.*; import java.util.concurrent.*; import java.util.*; class MyThreadPoolExecutor extends ThreadPoolExecutor { private boolean hasFinish = false; public MyThreadPoolExecutor(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit, BlockingQueue<Runnable> workQueue, RejectedExecutionHandler handler) { super(corePoolSize, maximumPoolSize, keepAliveTime, unit, workQueue, handler); // TODO Auto-generated constructor stub } public MyThreadPoolExecutor(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit, BlockingQueue<Runnable> workQueue, ThreadFactory threadFactory, RejectedExecutionHandler handler) { super(corePoolSize, maximumPoolSize, keepAliveTime, unit, workQueue, threadFactory, handler); // TODO Auto-generated constructor stub } public MyThreadPoolExecutor(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit, BlockingQueue<Runnable> workQueue, ThreadFactory threadFactory) { super(corePoolSize, maximumPoolSize, keepAliveTime, unit, workQueue, threadFactory); // TODO Auto-generated constructor stub } public MyThreadPoolExecutor(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit, BlockingQueue<Runnable> workQueue) { super(corePoolSize, maximumPoolSize, keepAliveTime, unit, workQueue); // TODO Auto-generated constructor stub } /* * (non-Javadoc) * * @see * java.util.concurrent.ThreadPoolExecutor#afterExecute(java.lang.Runnable, * java.lang.Throwable) */ @Override protected void afterExecute(Runnable r, Throwable t) { // TODO Auto-generated method stub super.afterExecute(r, t); synchronized (this) { System.out.println("自动调用了....afterEx 此时getActiveCount()值:" + this.getActiveCount()); if (this.getActiveCount() == 1)// 已执行完任务之后的最后一个线程 { this.hasFinish = true; this.notify(); }// if }// synchronized } public void isEndTask() { synchronized (this) { while (this.hasFinish == false) { System.out.println("等待线程池所有任务结束: wait..."); try { this.wait(); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } } }
?第一个程序结束
?
?
第二个程序开始
?
package cn.edu.xmu.dm.mt; import java.io.File; /** * 统计文件的主类 * @author chenwq * */ public class Manager { /** * @param args */ public static void main(String[] args) { File[] roots = File.listRoots();//系统的根目录数组 ThreadListener tl = new ThreadListener();//监听统计文件线程的监控线程 for(int i=0;i<roots.length;i++){//根据根目录创建统计文件线程 CountFile cf = new CountFile(roots[i]); tl.array.add(cf); cf.start(); } tl.start(); } }?package cn.edu.xmu.dm.mt;
/** * 统计文件的线程类 */ import java.io.File; public class CountFile extends Thread { // 根目录名 private File root; // 标志线程是否执行完毕的属性 private boolean finished; //要输出的信息 String info; // 构造器,传入一个根目录名 public CountFile(File root) { this.root = root; } // 查看线程是否已经执行完毕 public boolean isFinished() { return finished; } // 通过线程进行文件统计 public void run() { System.out.println(root+"盘文件统计开始"); int count = countProcess(root); info = root.getAbsolutePath()+"盘统计文件数为"+count+"\n"; finished = true; System.out.println(root+"盘文件统计完毕"); } private int countProcess(File dir) { int count = 0; if (!dir.exists()) {// 如果该文件指向的地址不存在 return count; } // 将文件中的子文件保存在文件数组中 File[] files = dir.listFiles(); if (files == null) {// 如果文件数组为空,则返回0 return count; } for (int i = 0; i < files.length; i++) { if (files[i].isDirectory()) {// 如果是文件夹 count += countProcess(files[i]); } else if (files[i].isFile()) {// 如果是标准文件 count++; } } return count; } }?
package cn.edu.xmu.dm.mt; /** * 监视统计线程的线程类 */ import java.util.ArrayList; public class ThreadListener extends Thread{ ArrayList<CountFile> array = new ArrayList<CountFile>(); String result=""; public void run(){ boolean flag=false; while(!flag){ for(int i=0;i<array.size();i++){ if(array.get(i).isFinished()){//判断统计文件的线程是否已经完成 result+=array.get(i).info; array.remove(i);//将已经完成的线程对象从队列中移除 } } try {//每隔一定时间监听一次各个文件统计线程 Thread.sleep(50); } catch (InterruptedException e) { e.printStackTrace(); } if(array.size()==0){//如果统计线程都已经完成 flag=true; System.out.println(result); } } } }?
?