标签:题记 port 没有 .exe call str strong java 不能
一些事情的阻隔,然后把好不容易形成的习惯改变。想着尝试改变,却处处触及底线,敛起触角,继续向前。不知不觉,距上次已有2个礼拜了。尔后,卿域非我,子视无卿。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),得到运行效果:
【题记】
笔者只是,遇到了然后亲测并记录下这个方法。若比优者,后定当存之。
标签:题记 port 没有 .exe call str strong java 不能
原文地址:http://blog.51cto.com/13479739/2308139