设置java函数的响应时间以及超时处理

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了设置java函数的响应时间以及超时处理相关的知识,希望对你有一定的参考价值。

一些事情的阻隔,然后把好不容易形成的习惯改变。想着尝试改变,却处处触及底线,敛起触角,继续向前。不知不觉,距上次已有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),得到运行效果:

技术分享图片

【题记】
笔者只是,遇到了然后亲测并记录下这个方法。若比优者,后定当存之。

以上是关于设置java函数的响应时间以及超时处理的主要内容,如果未能解决你的问题,请参考以下文章

如何为不接受取消令牌的异步函数设置超时?

java连接redis超时问题怎么解决

java-接收UDP包时设置超时函数java

nginx中的超时设置,请求超时响应等待超时等

HTTP请求的python实现(urlopenheaders处理 Cookie处理设置Timeout超时 重定向Proxy的设置)

ANR产生原因以及分析工具