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 利用这三种方式都可以实现定时执行任务。

创梦网络-江苏宿迁BGP云服务器100G高防资源,全程ceph集群存储,安全可靠,数据有保证,防护真实,现在购买7折促销,续费同价!

官方网站:点击访问创梦网络宿迁BGP高防活动方案:机房CPU内存硬盘带宽IP防护流量原价活动价开通方式宿迁BGP4vCPU4G40G+50G20Mbps1个100G不限流量299元/月 209.3元/月点击自助购买成都电信优化线路8vCPU8G40G+50G20Mbps1个100G不限流量399元/月 279.3元/月点击自助购买成都电信优化线路8vCPU16G40G+50G2...

HostKvm 黑色星期五香港服务器终身六折 其余机房八折

HostKvm商家我们也不用多介绍,这个服务商来自国内某商家,旗下也有多个品牌的,每次看到推送信息都是几个服务商品牌一起推送的。当然商家还是比较稳定的,商家品牌比较多,这也是国内商家一贯的做法,这样广撒网。这次看到黑五优惠活动发布了,针对其主打的香港云服务器提供终身6折的优惠,其余机房服务器依然是8折,另还有充值50美元赠送5美元的优惠活动,有需要的可以看看。HostKvm是一个创建于2013年的...

易探云服务器怎么过户/转让?云服务器PUSH实操步骤

易探云服务器怎么过户/转让?易探云支持云服务器PUSH功能,该功能可将云服务器过户给指定用户。可带价PUSH,收到PUSH请求的用户在接收云服务器的同时,系统会扣除接收方的款项,同时扣除相关手续费,然后将款项打到发送方的账户下。易探云“PUSH服务器”的这一功能,可以让用户将闲置云服务器转让给更多需要购买的用户!易探云服务器怎么过户/PUSH?1.PUSH双方必须为认证用户:2.买家未接收前,卖家...

scheduledexecutorservice为你推荐
webcrackwebcrack4.0smartupload使用SmartUpload实现文件上传时需要对表单设置哪些属性faq是什么意思在国际贸易中“FAQ”代表的是什么意思booth算法利用补码booth计算【xy】补,其中x=0.1110,y=-0.1101qq业务中心QQ业务办理优众网瑞达恒慧讯网是做什么的?qq号码查询如何查看自己手机的QQ号文件系统类型文件系统的类型是 NTFS。无法决定卷版本和状态。CHKDSK 被终止?工作日志系统新员工工作日志怎么写黄江论坛东莞黄江有多少个社区多少个村?都叫什么名字
成都虚拟空间 虚拟主机测评 godaddy域名解析教程 科迈动态域名 域名转接 卡巴斯基免费试用版 so域名 以下 cc攻击 免费网络电视软件 qq登陆空间 宿迁服务器托管 美国主机购买 个人web服务器 dhcp服务器是什么 运维堡垒主机 灵动:鬼影实录 创梦天地 北京购车摇号申请网站 英国伦敦白金汉宫 更多