java设置一段代码执行超时时间

本文介绍如何使用Java的Future类解决多线程操作中的超时问题,通过设置get()方法的timeout参数,实现超时后程序能够继续执行而不阻塞。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前段时间在搞一个批量处理程序,涉及到多线程操作。但是后台服务很不给力,并发一大常常就挂了,长时间不给返回,导致我的程序也挂死在那里……

那么能不能设置一段代码执行的超时时间呢?如果处理超时就忽略该错误继续向下执行。

可是在网上搜了大半天,找到的都是无用的代码,根本不能用。

查了大量资料后发现,java早已经给我们提供了解决方案。jdk1.5自带的并发库中Future类就能满足这个需求。Future类中重要方法包括get()和cancel()。get()获取数据对象,如果数据没有加载,就会阻塞直到取到数据,而 cancel()是取消数据加载。另外一个get(timeout)操作,表示如果在timeout时间内没有取到就失败返回,而不再阻塞。

到这里,此问题就迎刃而解了。废话不多说,直接上代码:

  1. import java.util.concurrent.Callable;
    import java.util.concurrent.ExecutionException;
    import java.util.concurrent.ExecutorService;
    import java.util.concurrent.Executors;
    import java.util.concurrent.TimeUnit;


    import com.sun.corba.se.impl.orbutil.closure.Future;
    import com.sun.corba.se.impl.orbutil.threadpool.TimeoutException;
  2. publicclassThreadTest{
  3. publicstaticvoidmain(String[]args)throwsInterruptedException,
  4. ExecutionException{
  5. finalExecutorServiceexec=Executors.newFixedThreadPool(1);
  6. Callable<String>call=newCallable<String>(){
  7. publicStringcall()throwsException{
  8. //开始执行耗时操作
  9. Thread.sleep(1000*5);
  10. return"线程执行完成.";
  11. }
  12. };
  13. try{
  14. Future<String>future=exec.submit(call);
  15. Stringobj=future.get(1000*1,TimeUnit.MILLISECONDS);//任务处理超时时间设为1秒
  16. System.out.println("任务成功返回:"+obj);
  17. }catch(TimeoutExceptionex){
  18. System.out.println("处理超时啦....");
  19. ex.printStackTrace();
  20. }catch(Exceptione){
  21. System.out.println("处理失败.");
  22. e.printStackTrace();
  23. }
  24. //关闭线程池
  25. exec.shutdown();
  26. }
  27. }
注意,以上代码需要 1.5 以上的 jdk 才可编译。
执行后可以发现抛出了 TimeoutException ,打印出了"处理超时啦...." 的文字,在此处可进行超时后的处理。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值