本文demo已上传至github:xinyuehtx/WCFdemo

在之前的2019-1-31-wcf入门(12) - huangtengxiao博客介绍了wcf的异步,但是发现一些小伙伴没有注意到的问题。因此做一些补充实验


异步代码会导致超时么

上一次我们发现当返回值至task时,消息一旦发出,线程就会继续执行。

那么继续利用上一个博客的例子,我们尝试将delay增加到3min,然后检查输出

1549002436165

1549001999160

1549002009961

结果输出我们可以看到所有调用都出现了超时。因此使用await等待仍然是会超时的,我们不能在服务端通过异步执行耗时过长的代码

1549001928438

小结

我们研究了WCF服务的异步代码的超时问题,其特点有

  • 即使使用async/await,仍然会超时

参考链接:


本文会经常更新,请阅读原文: https://xinyuehtx.github.io/post/wcf%E5%85%A5%E9%97%A8-13.html ,以避免陈旧错误知识的误导,同时有更好的阅读体验。

知识共享许可协议 本作品采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可。欢迎转载、使用、重新发布,但务必保留文章署名黄腾霄(包含链接: https://xinyuehtx.github.io ),不得用于商业目的,基于本文修改后的作品务必以相同的许可发布。如有任何疑问,请 与我联系