我有一个带有此签名的 API 方法:
public Task<MResponse> StartAsync(MRequest request)
我无法更改它(我可以更改内部实现,但不能更改方法的签名)。
我是这样称呼这个方法的:
var ret = await _SyncClient.StartAsync(Request);
这就是实现
public Task<MResponse> StartAsync(MRequest request)
{
if (request.Number == 1)
{
return new Task<MResponse>(() => new MResponse() { Description = "Error", Code = 1 });
}
else
{
return new Task<MResponse>(() => new MResponse() { Description = "", Code = 0 });
}
}
在调试模式下,我看到我的代码进入
StartAsync
,然后返回并完成它,但看起来等待永远不会结束......
我不知道它会是什么。
如果您需要有关我的代码的更多信息,请告诉我。
看起来您在实现中实际上没有任何异步操作要做。没关系,总会有设置签名(即接口)而某些实现不需要它的情况。
您仍然可以使用该方法
async
并返回响应,就好像它是同步方法一样,如下所示:
public async Task<MResponse> StartAsync(MRequest request)
{
return new MResponse() { ... }
}
但这可能会触发 Intellisense 告诉您方法中没有等待的内容。更好的方法是像这样使用
Task.FromResult
:
public Task<MResponse> StartAsync(MRequest request)
{
return Task.FromResult(new MResponse() ... );
}
这将返回一个已经完成的任务,因此不会阻止您的
await
后续行动。
您正在通过调用 任务构造函数
创建任务这会创建一个
Task
,但不会启动它。您必须显式调用 Task.Start
public Task<MResponse> StartAsync(MRequest request)
{
var task = (request.Number == 1)
? new Task<MResponse>(() => new MResponse() { Description = "Error", Code = 1 })
: new Task<MResponse>(() => new MResponse() { Description = "", Code = 0 });
task.Start();
return task;
}
您还有其他选择。您可以在当前线程上创建对象并将其作为已完成的任务返回
return Task.FromResult<MResponse>(new MResponse(...))
另一种选择是调用 Task.Run 来启动后台线程上的工作。
public Task<MResponse> StartAsync(MRequest request)
{
Func<MResponse> generateResponse = (request.Number == 1)
? () => new MResponse() { Description = "Error", Code = 1 })
: () => new MResponse() { Description = "", Code = 0 });
return Task.Run(generateResponse);
}