gpt4 book ai didi

java - 如何使用Java 11标准HTTPClient测量异步发送HTTP请求的耗时?

转载 作者:行者123 更新时间:2023-12-01 16:26:19 25 4
gpt4 key购买 nike

在一种方法中,我创建并发送一些异步 HTTPRequest,并将 CF 添加到列表中:

// HTTPClient is Java11 standard, package java.net.http;
CompletableFuture<HttpResponse<String>> httpResponseCF = this.httpClient.sendAsync(httpRequest, BodyHandlers.ofString());
list.add(httpResponseCF);

后来,在另一种方法中,我每隔 1 秒定期检查一些异步发送的 HTTPRequest 是否已收到:

for(CompletableFuture<HttpResponse<String>> httpResponseCF : list){
if (httpResponseCF.isDone()) {
//print out: The time between sending HTTPRequest and receiving HTTPResponse is 25ms
}
}

问题是,如何测量准确的请求时间?

最佳答案

像下面这样的东西应该可以解决问题:

long start = System.nanoTime();
CompletableFuture<HttpResponse<String>> httpResponseCF =
this.httpClient.sendAsync(httpRequest, BodyHandlers.ofString()).
whenComplete((r,t) -> System.out.println("elapsed ns: "
+ (System.nanoTime() - start)));

免责声明:我实际上还没有编译以上内容......这也不是确切时间,而是您可以获得的最佳近似时间。与所有事情一样,准确的时间是无法测量的。

关于java - 如何使用Java 11标准HTTPClient测量异步发送HTTP请求的耗时?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62136472/

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