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

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

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

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

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

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


  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. public class ThreadTest {  
  3.   
  4.     public static void main(String[] args) throws InterruptedException,  
  5.             ExecutionException {  
  6.           
  7.         final ExecutorService exec = Executors.newFixedThreadPool(1);  
  8.           
  9.         Callable<String> call = new Callable<String>() {  
  10.             public String call() throws Exception {  
  11.                 //开始执行耗时操作  
  12.                 Thread.sleep(1000 * 5);  
  13.                 return "线程执行完成.";  
  14.             }  
  15.         };  
  16.           
  17.         try {  
  18.             Future<String> future = exec.submit(call);  
  19.             String obj = future.get(1000 * 1, TimeUnit.MILLISECONDS); //任务处理超时时间设为 1 秒  
  20.             System.out.println("任务成功返回:" + obj);  
  21.         } catch (TimeoutException ex) {  
  22.             System.out.println("处理超时啦....");  
  23.             ex.printStackTrace();  
  24.         } catch (Exception e) {  
  25.             System.out.println("处理失败.");  
  26.             e.printStackTrace();  
  27.         }  
  28.         // 关闭线程池  
  29.         exec.shutdown();  
  30.     }  
  31. }  

注意,以上代码需要 1.5 以上的 jdk 才可编译。 
执行后可以发现抛出了 TimeoutException ,打印出了"处理超时啦...." 的文字,在此处可进行超时后的处理。

java超时控制

超时控制是我们在系统中容易忽视却又不能忽视的功能。一方面,超时并不是我们系统的主要业务功能,大多数超时控制已经被虚拟机或者服务器实现了;另一方面,超时控制是许多业务必备的隐性功能,试想,一个web应用...
  • liweisnake
  • liweisnake
  • 2013年01月03日 15:41
  • 2982

Java多线程任务超时结束的5种实现方法

在用Java编写并发程序时,往往会碰到某个线程因计算量大或因阻塞而一直处于无响应的情况,我们可能会等的不耐烦(也可能是不想让它占用太多资源)想及时终止掉它,那就需要用到任务超时结束的技巧了。在刚接触到...
  • wonking666
  • wonking666
  • 2017年03月22日 12:50
  • 4436

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

java设置一段代码执行超时时间
  • educast
  • educast
  • 2016年07月09日 06:30
  • 2500

java设置一段代码执行的超时时间的简单方法 间接实现获取Connection超时问题

最近有个需求, 当DB压力过大时获取Connction的时间过慢长时间不返回的话, 就不连接DB了, 研究了好久,DataSource里面的setLoginTimeOut 根本没法用, 刚开始一直纠结...
  • a1015088819
  • a1015088819
  • 2016年11月09日 15:01
  • 6828

Java线程超时控制的实现

一.何时需要超时控制   超时控制一般使用阻塞时间比较长的操作上,有可能是和远程数据库的连接,也有可能是网络下载,在程序超时后, 往往需要进行一些操作,比如退出线程,或者重新执行.   二...
  • zengkulou
  • zengkulou
  • 2012年12月18日 09:41
  • 1550

Java 多线程设置线程超时时间之 Callable接口和Future接口 超时控制

Callable接口和Future接口介绍         在Java中,如果需要设定代码执行的最长时间,即超时,可以用Java线程池ExecutorService类配合Future接口来实现。...
  • yangliuhbhd
  • yangliuhbhd
  • 2017年04月20日 17:33
  • 1267

java 1.7控制代码超时时间

防止重复提交有多种方法,有一种方法是操作数据之前先向一个临时表(有主键约束)中插入一条数据,这条数据可以是单据的主键id。当后续用户重复提交时,由于主键冲突就会报错,然后系统提示重复提交。但现在出现了...
  • guogang83
  • guogang83
  • 2017年04月26日 10:42
  • 746

Java任务超时处理机制实现

1问题描述     在应用软件的开发中,经常会遇到这样的一种需求:需要实现一个方法来执行某种任务,而这个方法的执行时间不能超过指定值,如果超时,则调用者不管这个方法将来是否可能执行成功,都要中断...
  • fangquan1980
  • fangquan1980
  • 2016年09月07日 16:10
  • 5456

Java实现限定方法执行时间-java 1.5以上的Future类可以执行超时处理

开发场景中有是需要对响应时间较长的接口或者方法进行处理,比如跳过继续执行,或者其它的方式,这个可以使用Future实现: 代码 -// 设置BI返回数据最长时间,如果超过此时间则跳过 Ca...
  • dangzhizheng
  • dangzhizheng
  • 2016年09月21日 20:37
  • 1829

java 设置超时

最近有个需求, 当DB压力过大时获取Connction的时间过慢长时间不返回的话, 就不连接DB了, 研究了好久,DataSource里面的setLoginTimeOut 根本没法用, 刚开始一直纠结...
  • zust6314
  • zust6314
  • 2015年01月05日 09:50
  • 426
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:java设置一段代码执行超时时间
举报原因:
原因补充:

(最多只允许输入30个字)