多线程,超时处理
2017-05-19 00:00
204 查看
摘要: 一段代码执行,设定时间,如果超时,就中断操作,继续后续操作。
1.使用线程池ExecutorService exec = Executors.newFixedThreadPool(1);
2.根据线程返回的结果Future,进行相应处理
demo如下:
、
package com.test;
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.TimeoutException;
public class TimeOutTest {
public static void main(String[] args) {
System.out.println("程序开始");
final ExecutorService exec = Executors.newFixedThreadPool(1);
Callable<String> call = new Callable<String>() {
public String call() throws Exception {
// 开始执行耗时操作
Thread.sleep(1000 * 3);
System.out.println("程序早结束了,已经没用了。");
return "线程执行完成.";
}
};
Future<String> future = null;
try {
future = exec.submit(call);
String obj = future.get(1000 * 1, TimeUnit.MILLISECONDS); // 任务处理超时时间设为 1 秒
System.out.println("任务成功返回:" + obj);
} catch (TimeoutException ex) {
System.out.println("处理超时啦....");
if(future!=null){
future.cancel(true);
}
} catch (Exception e) {
System.out.println("处理失败.");
}finally{
System.out.println("关闭线程池");
// 关闭线程池
exec.shutdown();
}
System.out.println("程序结束");
}
}
1.使用线程池ExecutorService exec = Executors.newFixedThreadPool(1);
2.根据线程返回的结果Future,进行相应处理
demo如下:
、
package com.test;
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.TimeoutException;
public class TimeOutTest {
public static void main(String[] args) {
System.out.println("程序开始");
final ExecutorService exec = Executors.newFixedThreadPool(1);
Callable<String> call = new Callable<String>() {
public String call() throws Exception {
// 开始执行耗时操作
Thread.sleep(1000 * 3);
System.out.println("程序早结束了,已经没用了。");
return "线程执行完成.";
}
};
Future<String> future = null;
try {
future = exec.submit(call);
String obj = future.get(1000 * 1, TimeUnit.MILLISECONDS); // 任务处理超时时间设为 1 秒
System.out.println("任务成功返回:" + obj);
} catch (TimeoutException ex) {
System.out.println("处理超时啦....");
if(future!=null){
future.cancel(true);
}
} catch (Exception e) {
System.out.println("处理失败.");
}finally{
System.out.println("关闭线程池");
// 关闭线程池
exec.shutdown();
}
System.out.println("程序结束");
}
}
相关文章推荐
- java多线程实现mq消息处理超时监控
- C#中的多线程超时处理实践
- 设置超时,处理cookie,多线程
- C#中的多线程超时处理实践方案
- C#中的多线程超时处理实践
- 多线程执行超时处理
- java中处理http连接超时
- Cookies,SSL,httpclient的多线程处理,HTTP方法 (zt)
- 批处理程序中的“多线程”处理
- 我搞得大数据量处理程序(几千万数据同时处理不会超时)
- 处理WinForm多线程程序时的陷阱
- 解决SqlTransaction用尽的问题(SQL处理超时)
- Tomcat+MySQL应用中连接超时造成各种异常情况的处理
- 在ASP.NET Atlas中调用Web Service——处理错误,超时以及响应用户的取消操作
- jni和c/c++多线程的处理
- 在connect中使用select实现超时处理
- 在处理多线程的程序时,要注意不要乱用关键字。
- 实用的PHP多线程处理
- 在ASP.NET Atlas中调用Web Service——处理错误,超时以及响应用户的取消操作
- 解决SqlTransaction用尽的问题(SQL处理超时)