5

在工作中,我目前卡在 3.5 中,但我们正在使用 asyncbridge 进行 async-await。我们正在使用很多旧的 WCF 异步调用,我想将其包装到新的 async-await 模式中。

我将其包装如下:

    // async is wrong
    public /*async*/ Task<ScannedDocumentResult> GetScannedDocumentsTask(String assignmentId)
    {
        TaskCompletionSource<ScannedDocumentResult> tcs = new TaskCompletionSource<ScannedDocumentResult>();
        EventHandler<GetScannedDocumentsCompletedEventArgs> handler = null;
        handler = (o, e) =>
            {
                if (e.UserState != tcs)
                    return;

                if (e.Error != null)
                    tcs.SetException(e.Error);
                else if (e.Cancelled)
                    tcs.SetCanceled();
                else
                    tcs.SetResult(e.Result);

                GetScannedDocumentsCompleted -= handler;
            };
        GetScannedDocumentsCompleted += handler;
        GetScannedDocumentsAsync(assignmentId, tcs);

        return tcs.Task;            
    }

以下是在 3.5 WCF 代理中生成的:

GetScannedDocumentsAsync GetScannedDocumentsCompleted GetScannedDocumentsEventArgs

有些东西告诉我,这可以做得更干净,我错过了一些重要的事情吗?

另外,这个方法会执行异步吗?使用 async 运算符编译只会产生错误。

4

1 回答 1

6

您还应该得到一个BeginGetScannedDocumentsand EndGetScannedDocuments,您可以使用TaskFactory.FromAsync. 我有一篇博客文章展示了如何将任务包装器与老式(4.5 之前)WCF(在服务器和客户端上)一起使用。

于 2013-08-21T12:21:06.090 回答