gpt4 book ai didi

java - 对于这个用例来说,什么是有效的设计

转载 作者:太空宇宙 更新时间:2023-11-04 14:40:51 25 4
gpt4 key购买 nike

我有一个用例,我在特定方法上启动计时器,看看它是否需要超过 x 秒。如果是这样,我将在日志中记录一个 fatal error ,如下所示。

private boolean isDpxTimedOut(StopWatch stopWatch)
{
stopWatch.stop();
long elapsedTime = stopWatch.getNanoTime();
Double elapsedTimeInSeconds = elapsedTime/NANO_DIVISOR;
return (elapsedTimeInSeconds >= DPX_TIMEOUT_VALUE);
}
public void callDPX()
{
try{
StopWatch stopWatch = new StopWatch();
//body of the method
}
catch(Exception e)
{
e.printStackTrace();
}
finally {
//putting a check here to see if DPX timed out and then logging a FATAL.
if(isDpxTimedOut(stopWatch))
{
log.fatal("[DPX TIMEOUT] The request took more than 12 seconds.");
}

}

现在我有一个用例,我必须将这个 stoip watch 放在不同类的多个方法上。我应该如何设计?不同类的超时会有所不同,应从配置文件中读取。有人可以为我指出一个适合此用例的良好设计吗?

最佳答案

尝试以下方法:

class Executor {
public static void execAndLogOnTimeout(Runnable runnable, long timeout) {
// Save start time
runnable.run();
// Save end time
// If time taken > timeout: log
}
}

Executor.execAndLogOnTimeout(new Runnable() {
@Override public void run() {
// The code to be clocked
}
}, Config.timeoutForThisPieceOfCode());

另一种选择是围绕建议使用 AOP。

关于java - 对于这个用例来说,什么是有效的设计,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24947561/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com