scheduledexecutorservice实现job和继承quartzjobbean的区别

scheduledexecutorservice  时间:2021-07-04  阅读:()

ExecutorService中submit和execute的区别

ExecutorService中submit和execute的区别   在Java5之后,并发线程这块发生了根本的变化,最重要的莫过于新的启动、调度、管理线程的一大堆API了。

在Java5以后,通过Executor来启动线程比用Thread的start()更好。

在新特征中,可以很容易控制线程的启动、执行和关闭过程,还可以很容易使用线程池的特性。

  一、创建任务   任务就是一个实现了Runnable接口的类。

  创建的时候实run方法即可。

  二、执行任务   通过java.util.concurrent.ExecutorService接口对象来执行任务,该接口对象通过工具类java.util.concurrent.Executors的静态方法来创建。

  Executors此包中所定义的 Executor、ExecutorService、ScheduledExecutorService、ThreadFactory 和 Callable 类的工厂和实用方法。

  ExecutorService提供了管理终止的方法,以及可为跟踪一个或多个异步任务执行状况而生成 Future 的方法。

可以关闭 ExecutorService,这将导致其停止接受新任务。

关闭后,执行程序将最后终止,这时没有任务在执行,也没有任务在等待执行,并且无法提交新任务。

  executorService.execute(new TestRunnable());   1、创建ExecutorService   通过工具类java.util.concurrent.Executors的静态方法来创建。

  Executors此包中所定义的 Executor、ExecutorService、ScheduledExecutorService、ThreadFactory 和 Callable 类的工厂和实用方法。

  比如,创建一个ExecutorService的实例,ExecutorService实际上是一个线程池的管理工具:   ExecutorService executorService = Executors.newCachedThreadPool();   ExecutorService executorService = Executors.newFixedThreadPool(3);   ExecutorService executorService = Executors.newSingleThreadExecutor();   2、将任务添加到线程去执行   当将一个任务添加到线程池中的时候,线程池会为每个任务创建一个线程,该线程会在之后的某个时刻自动执行。

  三、关闭执行服务对象   executorService.shutdown();   四、综合实例   package concurrent; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; /** * Created by IntelliJ IDEA. * * @author leizhimin 2008-11-25 14:28:59 */ lass TestCachedThreadPool { publicstaticvoid main(String[] args) { // ExecutorService executorService = Executors.newCachedThreadPool(); ExecutorService executorService = Executors.newFixedThreadPool(5);   // ExecutorService executorService = Executors.newSingleThreadExecutor(); for (int i = 0; i < 5; i++) { executorService.execute(new TestRunnable()); System.out.println("************* a" + i + " *************"); } executorService.shutdown(); } } class TestRunnable implements Runnable { publicvoid run() { System.out.println(Thread.currentThread().getName() + "线程被调用了。

"); while (true) { try { Thread.sleep(5000); System.out.println(Thread.currentThread().getName()); } catch (InterruptedException e) { e.printStackTrace(); } } } }   运行结果:   ************* a0 ************* ************* a1 ************* pool-1-thread-2线程被调用了。

************* a2 ************* pool-1-thread-3线程被调用了。

pool-1-thread-1线程被调用了。

************* a3 ************* ************* a4 ************* pool-1-thread-4线程被调用了。

pool-1-thread-5线程被调用了。

pool-1-thread-2 pool-1-thread-1 pool-1-thread-3 pool-1-thread-5 pool-1-thread-4 pool-1-thread-2 pool-1-thread-1 pool-1-thread-3 pool-1-thread-5 pool-1-thread-4 ......   五、获取任务的执行的返回值   在Java5之后,任务分两类:一类是实现了Runnable接口的类,一类是实现了Callable接口的类。

两者都可以被ExecutorService执行,但是Runnable任务没有返回值,而Callable任务有返回值。

并且Callable的call()方法只能通过ExecutorService的(<T> task) 方法来执行,并且返回一个 <T><T>,是表示任务等待完成的 Future。

  public interface Callable<V>   返回结果并且可能抛出异常的任务。

实现者定义了一个不带任何参数的叫做 call 的方法。

  Callable 接口类似于,两者都是为那些其实例可能被另一个线程执行的类设计的。

但是 Runnable 不会返回结果,并且无法抛出经过检查的异常。

  类包含一些从其他普通形式转换成 Callable 类的实用方法。

  Callable中的call()方法类似Runnable的run()方法,就是前者有返回值,后者没有。

  当将一个Callable的对象传递给ExecutorService的submit方法,则该call方法自动在一个线程上执行,并且会返回执行结果Future对象。

  同样,将Runnable的对象传递给ExecutorService的submit方法,则该run方法自动在一个线程上执行,并且会返回执行结果Future对象,但是在该Future对象上调用get方法,将返回null。

ExecutorService中submit和execute的区别

1、接收的参数不一样 2、submit有返回值,而execute没有 3、submit方便Exception处理 submit()能在返回的Future对象调用get()方法的时候再次抛出线程中的异常,而execute()会交由线程的UncaughtExceptionHandler去处理。

ExecutorService中submit和execute的区别

展开全部   在Java5之后,并发线程这块发生了根本的变化,最重要的莫过于新的启动、调度、管理线程的一大堆API了。

在Java5以后,通过 Executor来启动线程比用Thread的start()更好。

在新特征中,可以很容易控制线程的启动、执行和关闭过程,还可以很容易使用线程池的特 性。

  一、创建任务   任务就是一个实现了Runnable接口的类。

  创建的时候实run方法即可。

  二、执行任务   通过java.util.concurrent.ExecutorService接口对象来执行任务,该接口对象通过工具类java.util.concurrent.Executors的静态方法来创建。

  Executors此包中所定义的Executor、ExecutorService、ScheduledExecutorService、ThreadFactory 和Callable 类的工厂和实用方法。

  ExecutorService提供了管理终止的方法,以及可为跟踪一个或多个异步任务执行状况而生成 Future 的方法。

可以关闭 ExecutorService,这将导致其停止接受新任务。

关闭后,执行程序将最后终止,这时没有任务在执行,也没有任务在等待执行,并且无法提交新任务。

  executorService.execute(new TestRunnable());   转载,仅供参考。

实现job和继承quartzjobbean的区别

Thread java.util.Timer和java.util.TimerTask java.util.concurrent.ScheduledExecutorService 利用这三种方式都可以实现定时执行任务。

美国200G美国高防服务器16G,800元

美国高防服务器提速啦专业提供美国高防服务器,美国高防服务器租用,美国抗攻击服务器,高防御美国服务器租用等。我们的海外高防服务器带给您坚不可摧的DDoS防护,保障您的业务不受攻击影响。HostEase美国高防服务器位于加州和洛杉矶数据中心,均为国内访问速度最快最稳定的美国抗攻击机房,带给您快速的访问体验。我们的高防服务器配有最高层级的DDoS防护系统,每款抗攻击服务器均拥有免费DDoS防护额度,让您...

Cloudxtiny:£1.5/月,KVM-512MB/100GB/英国机房

Cloudxtiny是一家来自英国的主机商,提供VPS和独立服务器租用,在英国肯特自营数据中心,自己的硬件和网络(AS207059)。商家VPS主机基于KVM架构,开设在英国肯特机房,为了庆祝2021年欧洲杯决赛英格兰对意大利,商家为全场VPS主机提供50%的折扣直到7月31日,优惠后最低套餐每月1.5英镑起。我们对这场比赛有点偏见,但希望这是一场史诗般的决赛!下面列出几款主机套餐配置信息。CPU...

提速啦 韩国服务器 E3 16G 3IP 450元/月 韩国站群服务器 E3 16G 253IP 1100元/月

提速啦(www.tisula.com)是赣州王成璟网络科技有限公司旗下云服务器品牌,目前拥有在籍员工40人左右,社保在籍员工30人+,是正规的国内拥有IDC ICP ISP CDN 云牌照资质商家,2018-2021年连续4年获得CTG机房顶级金牌代理商荣誉 2021年赣州市于都县创业大赛三等奖,2020年于都电子商务示范企业,2021年于都县电子商务融合推广大使。资源优势介绍:Ceranetwo...

scheduledexecutorservice为你推荐
scanf_sscanf_s和以前的scanf是一样等级的吗???策略组简述组策略的概念 急急急策略组组策略是什么?foxmail邮箱注册如何注册FOXMAIL邮箱的帐号啊?查字网“很”去掉双人旁读什么?arc是什么意思arcsin中arc是什么的缩写? 怎么读? ?调度系统生产调度系统flowplayerswfobject.js这能不能播放音频啊(amr)ruby语言Ruby是一种什么样的语言,主要用来做什么,现在有一家公司让我从java转ruby,我很犹豫?ruby语言Ruby是 什么意思
河南虚拟主机 域名投资 北京服务器租用 北京vps主机 三级域名网站 westhost 狗爹 sub-process 网站实时监控 商务主机 gg广告 空间论坛 什么是服务器托管 网络空间租赁 服务器干什么用的 河南移动网 服务器监测 ca187 申请免费空间和域名 根服务器 更多