java并发二

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();
    }

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值