C#4.0的并行库TPL,即Task(七)

C#4.0的并行库TPL,即Task(一)http://www.skcircle.com/?id=1793

C#4.0的并行库TPL,即Task(二) http://www.skcircle.com/?id=1798

C#4.0的并行库TPL,即Task(三) http://www.skcircle.com/?id=1808

C#4.0的并行库TPL,即Task(四)  http://www.skcircle.com/?id=1815

C#4.0的并行库TPL,即Task(五) http://www.skcircle.com/?id=1816

C#4.0的并行库TPL,即Task(六) http://www.skcircle.com/?id=1831

C#4.0的并行库TPL,即Task(七)http://www.skcircle.com/?id=1850




勇哥继续这个话题,这一篇记录的问题如下:


TaskScheduler 调度器的TryExecuteTask方法,take出第一个方法后执行出现异常,异常很奇怪,居然是IsCanceled。

然尔我并没有取消任务!!!


image.png

(图1)  异常内容由vs的插件OzCode显示。


image.png

(图2)  异常内容由vs的插件OzCode显示。


搜索了网络,有人提到了这个问题,摘录如下:

-------------------------------------------------------------


错误内容:

System.Threading.Tasks.TaskCanceledException: A task was canceled.
   at Microsoft.EntityFrameworkCore.Storage.RelationalConnection.OpenDbConnectionAsync(Boolean errorsExpected, CancellationToken cancellationToken)
   at Microsoft.EntityFrameworkCore.Storage.RelationalConnection.OpenDbConnectionAsync(Boolean errorsExpected, CancellationToken cancellationToken)
   at Microsoft.EntityFrameworkCore.Storage.RelationalConnection.OpenAsync(CancellationToken cancellationToken, Boolean errorsExpected)
   at Microsoft.EntityFrameworkCore.Storage.RelationalCommand.ExecuteReaderAsync(RelationalCommandParameterObject parameterObject, CancellationToken cancellationToken)
   at Microsoft.EntityFrameworkCore.Query.RelationalShapedQueryCompilingExpressionVisitor.AsyncQueryingEnumerable`1.AsyncEnumerator.MoveNextAsync() System.Threading.Tasks.TaskCanceledException: A task was canceled.
   at Microsoft.EntityFrameworkCore.Storage.RelationalConnection.OpenDbConnectionAsync(Boolean errorsExpected, CancellationToken cancellationToken)
   at Microsoft.EntityFrameworkCore.Storage.RelationalConnection.OpenDbConnectionAsync(Boolean errorsExpected, CancellationToken cancellationToken)
   at Microsoft.EntityFrameworkCore.Storage.RelationalConnection.OpenAsync(CancellationToken cancellationToken, Boolean errorsExpected)
   at Microsoft.EntityFrameworkCore.Storage.RelationalCommand.ExecuteReaderAsync(RelationalCommandParameterObject parameterObject, CancellationToken cancellationToken)
   at Microsoft.EntityFrameworkCore.Query.RelationalShapedQueryCompilingExpressionVisitor.AsyncQueryingEnumerable`1.AsyncEnumerator.MoveNextAsync()

现象:日志记录工具记录了以上错误,但程序正常运行。

原因:项目内某些方法是异步的,但是调用的时候是同步调用的,才会报这个错

解决办法:修改方法,用异步的方式调用异步方法,用同步的方式调用同步方法,解决!

-------------------------------------------------------------


其实,在百度上搜索这个问题之前,勇哥也做过实验,把TaskScheduler 调度器调用的异步方法更换为同步方法,则不会有这种问题。

因此也是估计问题出在同步代码调用异步代码的问题上面。

原则上应该保证异步方法调用异步方法,一直这种串下去。但是我的代码是以同步代码书写的,只是部分使用异步代码,如此看来,臣妄真得做不到呀!



这个问题的解决办法见下面贴子,其2楼的答案解决了我目前的问题:

MSDN论坛问题贴子:如何在C#中从同步方法调用异步方法?  http://www.skcircle.com/?id=1851





本文出自勇哥的网站《少有人走的路》wwww.skcircle.com,转载请注明出处!讨论可扫码加群:

发表评论:

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

会员中心
搜索
«    2024年4月    »
1234567
891011121314
15161718192021
22232425262728
2930
网站分类
标签列表
最新留言
    热门文章 | 热评文章 | 随机文章
文章归档
友情链接
  • 订阅本站的 RSS 2.0 新闻聚合
  • 扫描加本站机器视觉QQ群,验证答案为:halcon勇哥的机器视觉
  • 点击查阅微信群二维码
  • 扫描加勇哥的非标自动化群,验证答案:C#/C++/VB勇哥的非标自动化群
  • 扫描加站长微信:站长微信:abc496103864
  • 扫描加站长QQ:
  • 扫描赞赏本站:
  • 留言板:

Powered By Z-BlogPHP 1.7.2

Copyright Your skcircle.com Rights Reserved.

鄂ICP备18008319号


站长QQ:496103864 微信:abc496103864