一些事情的阻隔,然后把好不容易形成的习惯改变。想着尝试改变,却处处触及底线,敛起触角,继续向前。不知不觉,距上次已有2个礼拜了。尔后,卿域非我,子视无卿。
一、应用场景
在有些时候,我们利用debug运行一段代码的时候。会发现,当运行到某处时,编译器久久没有反应。这个过程,假设调用了别人的代码,或者远程的代码或者服务的时候出现的,亦或是自身代码的原因。我们暂时无法预测他的发生,亦或者是无法预期的事,例如远端服务断电,服务宕掉,本地连接尚未关闭。但出现这种情况,不能让人家干等着吧。况且,等个几小时也是白白的徒劳没有效果。
二、 计算Java响应时间,以及超时的处理机制。
(1)计算Java响应时间,可能最初浮现的方法就是下面的方式:
long starttime = System.currentTimeMillis();//记录起始时间
//中间放置,需要计算时间的代码
long endtime = System.currentTimeMillis();//记录结束时间
代码调优的必备,测试计算时间方法。
(2)给代码设置最大响应时间,超时执行异常处理的方法:
实例代码:
package com.css.java.learning.action;
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;
import java.util.concurrent.TimeUnit;
public class JavaSetTime {
public static void main(String[] args) {
Callable<String> task = new Callable<String>() {
@Override
public String call() throws Exception {
//设置执行响应时间的方法体
String str = JavaSetTime.sleepJavaTest();
System.err.println("打印str"+str);
return str;
}
};
ExecutorService exeservices = Executors.newSingleThreadExecutor();
Future<String> future = exeservices.submit(task);
try {
//设置方法
String result = future.get(5, TimeUnit.SECONDS);
System.err.println("打印result"+result);
} catch (Exception e) {
e.printStackTrace();
//异常处理的方法
System.err.println("5秒钟没有执行完毕!这里是异常处理的方法");
}
}
public static String sleepJavaTest() {
try {
/*java中sleep与wait的区别
* 对于sleep方法导致程序暂停执行指定的时间,让出cpu给其他线程。但是它的监控状态依然保持,时间到了就会恢复。
* 在sleep方法中,线程不会释放对象锁。
* 对于wait方法,线程会放弃对象锁,进入等待次对象的等待锁定池,
* 只有针对此对象调用notify()后,本线程才进入对象锁定池的准备。
*/
Thread.sleep(6000);
return "当前函数成功的返回";
} catch (InterruptedException e) {
e.printStackTrace();
return "执行异常";
}
}
}.
当我们给执行的方法体设置超出预定的时间的时候:
运行结果:
当给出的方法体执行时间在预定的范围之内时
Thread.sleep(4000),得到运行效果:
【题记】
笔者只是,遇到了然后亲测并记录下这个方法。若比优者,后定当存之。
原文地址:http://blog.51cto.com/13479739/2308139
时间: 2024-10-21 17:09:01