在一种方法中,我创建并发送一些HTTPRequests异步消息,然后将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)));


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

10-08 16:44