java并发二
来源:互联网 发布:windows webpack 安装 编辑:程序博客网 时间:2024/06/15 06:16
1.通过继续修改ThreadPoolExectutor可以自定义自己的执行类
2.ThreadPoolExecutor executors = new ThreadPoolExecutor(size, size, 10, TimeUnit.SECONDS, new PriorityBlockingQueue());
通过使任务实现runnable和comparable,在任务队列忙得时候,可以实现任务执行的排序。
3.利用threadFactory接口,生成自己的类
/**
*
*/
package thread.threadfactory;
import java.util.Date;
import java.util.concurrent.ThreadFactory;
import java.util.concurrent.TimeUnit;
/**
* @author Administrator
*
*/
public class MyThreadFactory implements ThreadFactory {
private String prefix;private int count;/** * @param prefix * @param count */public MyThreadFactory(String prefix) { this.prefix = prefix; this.count = 1;}/* (non-Javadoc) * @see java.util.concurrent.ThreadFactory#newThread(java.lang.Runnable) */public Thread newThread(Runnable r) { MyThread thread = new MyThread(r, prefix+"-"+count); this.count++; return thread;}private class MyThread extends Thread{ private Date createdDate; private Date startDate; private Date finishDate; public MyThread(Runnable r,String name){ super(r, name); setCreateDate(); } /* (non-Javadoc) * @see java.lang.Thread#run() */ @Override public void run() { setStartDate(); super.run(); setFinishDate(); } public void setStartDate(){ this.startDate = new Date(); } public void setFinishDate(){ this.finishDate = new Date(); } public void setCreateDate(){ this.createdDate = new Date(); } /* (non-Javadoc) * @see java.lang.Object#toString() */ @Override public String toString() { return "MyThread [createdDate=" + createdDate + ", startDate=" + startDate + ", finishDate=" + finishDate + "]"; }}public static void main(String[] args) { MyThreadFactory factory = new MyThreadFactory("sss"); Thread newThread = factory.newThread(new Runnable() { public void run() { System.out.println("执行XXXX"); try { TimeUnit.SECONDS.sleep(10); } catch (InterruptedException e) { e.printStackTrace(); } } }); newThread.start(); try { newThread.join(); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } if(!newThread.isAlive()){ System.out.println(newThread.toString()); }}
}
/**
*
*/
package thread.threadfactory;
import java.util.Date;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.ThreadFactory;
import java.util.concurrent.TimeUnit;
/**
* @author Administrator
*
*/
public class MyThreadFactory implements ThreadFactory {
private String prefix;private int count;/** * @param prefix * @param count */public MyThreadFactory(String prefix) { this.prefix = prefix; this.count = 1;}/* (non-Javadoc) * @see java.util.concurrent.ThreadFactory#newThread(java.lang.Runnable) */public Thread newThread(Runnable r) { MyThread thread = new MyThread(r, prefix+"-"+count); this.count++; return thread;}private class MyThread extends Thread{ private Date createdDate; private Date startDate; private Date finishDate; public MyThread(Runnable r,String name){ super(r, name); setCreateDate(); } /* (non-Javadoc) * @see java.lang.Thread#run() */ @Override public void run() { setStartDate(); super.run(); setFinishDate(); } public void setStartDate(){ this.startDate = new Date(); } public void setFinishDate(){ this.finishDate = new Date(); } public void setCreateDate(){ this.createdDate = new Date(); } /* (non-Javadoc) * @see java.lang.Object#toString() */ @Override public String toString() { return "MyThread [createdDate=" + createdDate + ", startDate=" + startDate + ", finishDate=" + finishDate + "]"; }}public static void main(String[] args) { /*MyThreadFactory factory = new MyThreadFactory("sss"); Thread newThread = factory.newThread(new Runnable() { public void run() { System.out.println("执行XXXX"); try { TimeUnit.SECONDS.sleep(10); } catch (InterruptedException e) { e.printStackTrace(); } } }); newThread.start(); try { newThread.join(); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } if(!newThread.isAlive()){ System.out.println(newThread.toString()); }*/ MyThreadFactory factory = new MyThreadFactory("MyThreadFactory"); ExecutorService newCachedThreadPool = Executors.newCachedThreadPool(factory); newCachedThreadPool.submit(new Runnable() { public void run() { System.out.println("执行XXXX"); try { TimeUnit.SECONDS.sleep(10); } catch (InterruptedException e) { e.printStackTrace(); } } }); newCachedThreadPool.shutdown(); try { boolean awaitTermination = newCachedThreadPool.awaitTermination(10, TimeUnit.SECONDS); if(awaitTermination){ System.out.println("任务结束"); } } catch (InterruptedException e) { e.printStackTrace(); }}
}
- java并发二
- Java并发(二)
- Java并发 基础 二
- Java并发编程二
- <读书笔记--并发>二、java并发机制
- Java 并发深入学习二
- Java的并发(二)
- JAVA并发编程笔记二
- Java并发编程(二)
- Java并发之volatile二
- Java的并发(二) 同步
- JAVA并发-显式锁(二)
- Java 并发总结(二)
- Java并发编程总结二
- Java并发读书笔记(二)
- java并发编程之二
- Java并发学习(二)-JMM
- java多线程与并发之java并发编程实践(二)
- 【黑马程序员】Java笔记——抽象类: abstract
- 每天一个linux命令(14):less 命令
- this 关键字的应用
- Java心得3
- iOS优化之路
- java并发二
- DialogFragment 使用与友好交互
- eclipse的Toggle Block Selection Mode功能---列模式
- SQLServer全文索引
- [2015-07-30] python011
- 2015.07.30总结
- Inorder Traversal a BST with Constant Extra Space
- c++ primer (5th) 第九章,顺序容器
- JAVA设计模式——代理模式