在线程中执行某方法,如果超出执行时间后立即抛出异常。停止该方法继续执行。
import java.lang.reflect.Method;
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.FutureTask;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.TimeoutException;
/**
* 方法超过执行时间后抛出异常
* @author Gary Huang
* create Time;2014-12-2
* email: 834865081@qq.com
* Copyright:归个人所有,转载请表名 出处
* 个人博客地址:http://blog.csdn.net/hfmbook
* */
public class CallMethod {
/***
* 方法参数说明
* @param target 调用方法的当前对象
* @param methodName 方法名称
* @param parameterTypes 调用方法的参数类型
* @param params 参数 可以传递多个参数
*
* */
public static Object callMethod(final Object target , final String methodName ,final Class<?>[] parameterTypes,final Object[]params){
ExecutorService executorService = Executors.newSingleThreadExecutor();
FutureTask<String> future = new FutureTask<String>(new Callable<String>() {
public String call() throws Exception {
String value = null ;
try {
Method method = null ;
method = target.getClass().getDeclaredMethod(methodName , parameterTypes ) ;
Object returnValue = method.invoke(target, params) ;
value = returnValue != null ? returnValue.toString() : null ;
} catch (Exception e) {
e.printStackTrace() ;
throw e ;
}
return value ;
}
});
executorService.execute(future);
String result = null;
try{
/**获取方法返回值 并设定方法执行的时间为10秒*/
result = future.get(10 , TimeUnit.SECONDS );
}catch (InterruptedException e) {
future.cancel(true);
System.out.println("方法执行中断");
}catch (ExecutionException e) {
future.cancel(true);
System.out.println("Excuti on异常");
}catch (TimeoutException e) {
future.cancel(true);
throw new RuntimeException("invoke timeout" , e );
}
executorService.shutdownNow();
return result ;
}
public Object call(Integer id){
try {
Thread.sleep( 11000 ) ;
} catch (Exception e) {
}
return id ;
}
public static void main(String[] args) {
System.out.println( callMethod(new CallMethod(), "call" , new Class<?>[]{Integer.class}, new Object[]{ 1523 } ) ) ;
}
}
版权声明:本文为hfmbook原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。