随笔 - 502  文章 - 1 评论 - 6 阅读 - 37万
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

复制代码
package other;

import java.util.concurrent.Callable;
import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.ScheduledFuture;
import java.util.concurrent.ThreadFactory;
import java.util.concurrent.TimeUnit;

public class TestScheduledThreadPool {
    
    public static void main(String[] args) {
        MyThreadFactory threadFactory = new MyThreadFactory();
        //ScheduledThreadPoolExecutor 
        //        继承 ThreadPoolExecutor            线程池
        //        实现ScheduledExecutorService  线程调度
        ScheduledExecutorService ses = Executors.newScheduledThreadPool(3, threadFactory);
        System.out.println("reday go.");
        
        
        TimeUnit unit = TimeUnit.SECONDS;
        //延时任务
        ses.schedule(new Runnable() {
            @Override
            public void run() {
                // TODO Auto-generated method stub
                System.out.println(Thread.currentThread().getName() + "delay Runnable");
            }
        }, 1, unit);
        
        //延时任务 带返回值
        ScheduledFuture<Integer> scheduledFuture = ses.schedule(new Callable<Integer>() {
                @Override
                public Integer call() throws Exception {
                    System.out.println(Thread.currentThread().getName() + "delay Callable");
                    return (int)(Math.random()*1000);
                }
            }, 1, unit);
        try {
            System.out.println(scheduledFuture.get());
        } catch (Exception e1) {
            e1.printStackTrace();
        }
        
        //循环执行
        //以开始时间 计算 下一次任务开始时间, 如果任务执行超出循环时间,则会任务执行完后再次执行
        /*ses.scheduleAtFixedRate(new Runnable() {
            @Override
            public void run() {
                // TODO Auto-generated method stub
                System.out.println(Thread.currentThread().getName() + " scheduleAtFixedRate begin:" + DataThreadLoadUtil.convertToStr(new Date()));
                try {
                    Thread.sleep(2000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                System.out.println(Thread.currentThread().getName() + " scheduleAtFixedRate end:" + DataThreadLoadUtil.convertToStr(new Date()));
            }
        }, 0, 1, unit);*/
        
        //循环执行
        //以结束时间 计算下一次执行时间
        /*ses.scheduleWithFixedDelay(new Runnable() {
            @Override
            public void run() {
                // TODO Auto-generated method stub
                System.out.println(Thread.currentThread().getName() + " scheduleWithFixedDelay begin:" + DataThreadLoadUtil.convertToStr(new Date()));
                try {
                    Thread.sleep(2000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                System.out.println(Thread.currentThread().getName() + " scheduleWithFixedDelay end:" + DataThreadLoadUtil.convertToStr(new Date()));
            }
        }, 0, 5, unit);*/
        
        /*for (int i = 0; i < 10; i++) {
            ses.submit(new Callable<Integer>() {
                @Override
                public Integer call() throws Exception {
                    // TODO Auto-generated method stub
                    System.out.println(Thread.currentThread().getName() + "---------");
                    return (int)(Math.random()*1000);
                }
            });
        }*/
        
        System.out.println("==========end");
        //ses.shutdown();
    }
}

class MyThreadFactory implements ThreadFactory {
    @Override
    public Thread newThread(Runnable r) {
        // TODO Auto-generated method stub
        System.out.println("ThreadFactory new Thread");
        return new Thread(r);
    }
    
}
复制代码

 

posted on   1161588342  阅读(998)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)
点击右上角即可分享
微信分享提示