java异步执行任务,结合多线程线程池
来源:互联网 发布:哪本书 java 算法程序 编辑:程序博客网 时间:2024/04/28 02:58
使用线程池结合异步处理完成一些需要立即返回结果,但计算量又相对比较大的计算任务,可以考虑使用这种异步任务,这边主要是利用java自身的Timer 任务调度中的异步操作,然后结合上线程池Executors.newCachedThreadPool进行使用。我这边主要示例一个不需要返回计算或者执行结果的任务,如果大家需要获取执行结果,可以考虑使用futureTask进行执行完堵塞式回调。这边我就不多讲futureTask这块,这边有个连接FutureTask使用案例大家可以自己学习下
那么Timer又是怎么执行异步任务的呢?
Timer timer = new Timer();timer.schedule(new TimerTask(){@Overridepublic void run() {List<String> allProvices = headCityMapper.getAllProvices();if(CollectionUtils.isNotEmpty(allProvices)){try {long startTime = System.currentTimeMillis();ExecutorService executorService = Executors.newCachedThreadPool();for(String currentProvice:allProvices){executorService.submit(()->{udProvinceCache(currentProvice);});}long endTime = System.currentTimeMillis();log.info(" 耗时(毫秒): {}" + (endTime-startTime));}catch (Exception e) {log.error("失败");}}}}, 1);如例中所示:1、schedule传入的第一个参数是一个TimerTask匿名类,第二个参数是延迟1毫秒。
2、多线程池ExecutorService executorService = Executors.newCachedThreadPool();新建一个线程池来处理任务;
3、"()->udProvinceCache(currentProvice)"这里面就是你具体要执行的任务,它其实是一个@functionalIterface接口话方法,支持这种函数调用的方式。会自动将你的任务注入到Runnable的run方法中去,作为方法的具体实例,这样就可以实现高效的异步任务。
1 0
- java异步执行任务,结合多线程线程池
- Java多线程--任务执行(线程池)
- 多线程执行job任务 线程池
- 一心多用多线程-future-java线程中的异步执行
- Java多线程之线程安全与异步执行
- java并发 -线程池,任务执行
- Java多线程交替执行任务
- java线程池中任务执行完成后再次执行
- 多线程异步编程(1):创建多个线程执行任务,同时更新进度条,使用WaitHandle发送信号
- java 异步执行任务,返回进度
- Java模拟耗时任务异步执行
- 【java学习】线程和异步任务机制
- 多线程线程池控制一个方法的并发量 限制只有5个线程执行任务
- Java多线程——获取多个线程任务执行完的时间
- OKHttp3源码分析<CacheThreadPool线程池异步请求任务的执行>
- 线程池任务执行流程
- Spring线程池执行任务
- 【捕获Java线程池执行任务抛出的异常】
- Java知识图谱收集整理
- C语言面向对象编程——读书《C嵌入式设计模式》
- linux下的SecureCRT安装和破解
- 经验心得记录
- 模型评估和选择——周志华的机器学习
- java异步执行任务,结合多线程线程池
- 这是第一篇
- hjr学习-网络安全:CMS注入
- 很好用的Python框架Bottle
- 【数据库SQL】SQL存储过程使用案例
- C#Tostring()格式转换
- 临时禁用Resharper
- 纯CSS3实现的鼠标悬停时边框旋转
- Android自定义一个广播接收器BroadcastReceiver监听本地消息