草庐IT

SpringBoot中异步注解@Async介绍

全部标签

c# - MessageQueue 和异步/等待

我只想在异步方法中接收我的消息!它卡住了我的用户界面publicasyncvoidProcessMessages(){MessageQueueMyMessageQueue=newMessageQueue(@".\private$\MyTransactionalQueue");MyMessageQueue.Formatter=newXmlMessageFormatter(newType[]{typeof(string)});while(true){MessageQueueTransactionMessageQueueTransaction=newMessageQueueTransacti

c# - 如何从 C# 中的异步任务 <bool> 函数获取 bool 结果 - 错误 : Cannot implicitly convert type `void' to `bool'

我已经创建了任务函数来验证我的json文件。一切正常,直到我没有使用结果。当我试图从asynctaskfunction获得结果时它显示错误为Cannotimplicitlyconvert'void'tobool.我的异步函数如下:privateasyncTaskMyValidationFunction(stringjson){boolisValid=true;.......DOINGMYVALIDATIONSTUFF.....returnisValid;}从另一个函数调用这个函数如下:publicboolGetJsonAndValidate(){boolisValid=true;str

C# 5 async/await 线程机制感觉不对?

为什么调用线程要进入异步方法直到内部'await'?调用异步方法后立即生成一个线程不是更干净吗?这样您就可以确定异步方法会立即返回。您不必担心在异步方法的早期阶段没有做任何昂贵的事情。我倾向于知道一个方法是否会在“我的”线程上执行代码。不管堵不堵。该模型似乎开启了一系列介于两者之间的可能性。设计师比我聪明得多,所以我确信这是有充分理由的,我只是想好好想想。 最佳答案 Isn'titcleanertojustspawnathreadassoonasanasyncmethodiscalled.“异步”方法的全部意义在于避免生成新线程。您

c# - 异步世界中的故障安全处置

在同步世界中,C#使一次性管理所有事物变得非常容易:using(IDisposablesomeDisposable=bla.bla()){//doourbidding}//don'tworrytoomuchaboutit但是,当我们使用异步时,我们不再享受usingblock带来的便利。我遇到的最好的策略之一是CCRiterator这允许我们使用异步代码“就好像它是同步的”。这意味着我们可以将usingblock保留在迭代器处理程序中,而不会陷入何时处理和捕获所有需要处理的情况的复杂决定中。但是,在许多情况下,调用CCR似乎有点矫枉过正,老实说,虽然我对CCR很满意,但对于外行来说,它

c# - 在异步方法中显示错误消息的更好方法

事实上我们不能使用awaitcatch中的关键字block使得在WinRT中显示来自异步方法的错误消息非常尴尬,因为MessageDialogAPI是异步的。理想情况下,我希望能够这样写:privateasyncTaskDoSomethingAsync(){try{//Somecodethatcanthrowanexception...}catch(Exceptionex){vardialog=newMessageDialog("Somethingwentwrong!");awaitdialog.ShowAsync();}}但是我必须这样写:privateasyncTaskDoSome

c# - 在 ASP.NET 中异步填充数据集或数据表的最佳做法是什么?

鉴于以下代码,我有几个关于最佳实践的问题:stringconnectionString=@"Server=(local)\sqlexpress;Database=master;IntegratedSecurity=true;";using(SqlConnectionconnection=newSqlConnection(connectionString)){using(SqlDataAdapterdataAdapter=newSqlDataAdapter("select*frominformation_schema.columns",connection)){awaitconnecti

c# - 如何将 IEumerable 集合添加到队列并在 .NET 中异步处理每个项目?

我已经创建了一个方法来使用交换服务器读取收件箱新消息,如下所示。如何将这些IEnumerable集合添加到队列并异步处理队列中的每个项目列表?privatestaticIEnumerableGetInboxItems(ExchangeServiceservice){varemailInformations=newList();try{SearchFiltersearchFilter=newSearchFilter.SearchFilterCollection(LogicalOperator.And,newSearchFilter.IsEqualTo(EmailMessageSchema

c# - 使用 async/await 时如何更好地处理已处置的控件

考虑在UI线程上运行的这段代码:dividends=awaitDatabase.GetDividends();if(IsDisposed)return;//DoexpensiveUIworkhereearnings=awaitDatabase.GetEarnings();if(IsDisposed)return;//DoexpensiveUIworkhere//etc...注意每次我await我也查了IsDisposed.这是必要的,因为说我await长期运行Task.同时,用户在完成之前关闭表单。Task将完成并运行尝试访问已处理表单上的控件的延续。发生异常。有没有更好的方法来处理这

c# - ReactiveUI 中的 TestScheduler 异步方法死锁

我正在尝试在测试中使用带有异步方法的reactiveui测试调度程序。等待异步调用时测试挂起。根本原因似乎是在异步方法中等待的命令。[Fact]publicasyncTaskTest()=>awaitnewTestScheduler().With(asyncscheduler=>{awaitSomeAsyncMethod();//***executionnevergetshereDebugger.Break();});privateasyncTaskSomeAsyncMethod(){varcommand=ReactiveCommand.CreateFromTask(async()=>

c# - 如何连接异步枚举?

我有一个具有此返回类型的方法:publicasyncTask>GetAll()它进行了一些进一步的异步调用(未知数量),每个调用返回一个可枚举T的任务,然后想要连接结果以返回。vardata1=src1.GetAll();vardata2=src2.GetAll();vardata3=src3.GetAll();//andsoon现在很容易等待所有结果并连接结果以生成单个可枚举项,但我希望在第一次调用返回后立即使用可枚举项,如果有任何调用,则可能会等待调用者/枚举器当可用结果用完时仍然悬而未决。我是否必须为此手动滚动一个concat,以解决当它包装在任务中时缺少枚举器支持的问题?或者在