3

我提出这个问题的动机是因为我正在创建一个 .net Web API 项目,该项目将使用具有同步方法的现有 neo4j rest api 客户端。我想通过使用异步方法来利用一些性能提升,但我想避免进入 neo4j api 库并重构同步方法以返回异步方法。我想知道是否将对同步方法的调用包装在 await Task.Run() 中是否有益。具体来说,在第一个示例中,当来自 httpClient 的异步结果调用 Wait() 方法时会发生什么,但整个事情都包装在另一个 await 中。

还要记住,我将在 AppHarbor 云上运行它,我认为它是一个单一的虚拟核心。

以下也是

  //what happens with the synchronous rest api client I am using
  HttpResponseMessage SendHttpRequest(HttpRequestMessage request)
  {

        var requestTask = httpClient.SendAsync(request);
        requestTask.Wait();
        return requestTask.Result;

  }

  object result = await Task.Run(() =>
  {
      return SendHttpRequest(request);
  });

性能类似

 return httpClient.SendAsync(request)
4

2 回答 2

8

我想通过使用异步方法来利用一些性能提升,但我想避免进入 neo4j api 库并重构同步方法以返回异步方法。

抱歉,async如果您只是将同步代码包装在Task.Run.

async在服务器上很好,因为异步操作比线程更好地扩展。但是,如果您正在使用Task.Run,那么无论如何您都在使用线程。

于 2012-10-26T04:20:28.953 回答
3

不同之处在于 Task.Run 方法只是在线程池上运行相同的阻塞代码。这意味着虽然它不会阻塞您的调用线程,但它会阻塞执行线程。

这有多重要完全取决于资源和性能方面的考虑。

如果 SendHttpRequest 方法真的只是在等待 httpClient.SendAsync 任务,您可以简单地避免该方法并编写:

object result = await httpClient.SendAsync(request);

或者:

object result = await Task.Run(async () => await httpClient.SendAsync(request));

如果 SendAsync 任务仍应在单独的线程上运行。

于 2012-10-25T16:35:05.180 回答