码迷,mamicode.com
首页 > 编程语言 > 详细

java 方法超过执行时间后抛出异常

时间:2014-12-02 15:14:47      阅读:216      评论:0      收藏:0      [点我收藏+]

标签:blog   http   io   ar   os   java   on   2014   log   


在线程中执行某方法,如果超出执行时间后立即抛出异常。停止该方法继续执行。

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 } ) ) ; 
	}
}


java 方法超过执行时间后抛出异常

标签:blog   http   io   ar   os   java   on   2014   log   

原文地址:http://blog.csdn.net/hfmbook/article/details/41678861

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!