草庐IT

CancellationToken

全部标签

c# - 将 WAV 录制到 IBM Watson Speech-To-Text

我正在尝试录制音频并立即将其发送到IBMWatsonSpeech-To-Text进行转录。我已经使用从磁盘加载的WAV文件测试了Watson,并且成功了。另一方面,我还测试了从麦克风录音并将其存储到磁盘,效果也很好。但是当我尝试使用NAudioWaveIn录制音频时,Watson的结果是空的,就好像没有音频一样。谁能对此有所启发,或者有人有一些想法?privateasyncvoidStartHere(){varws=newClientWebSocket();ws.Options.Credentials=newNetworkCredential("*****","*****");awai

c# - default(CancellationToken) 如何有相应的 CancellationTokenSource

当我创建默认的CancellationToken时,我可以在调试器中看到CancellationToken有一个与其关联的CancellationTokenSource,它存储在私有(private)m_source字段:我想知道对于default关键字"willreturneachmemberofthestructinitializedtozeroornulldependingonwhethertheyarevalueorreferencetypes"的结构怎么可能呢?CancellationTokenSource是引用类型。CancellationToken确实有2个构造函数来设置

c# - 用最小起订量模拟 MediatR 3

我们最近开始使用MediatR来整理Controller操作,因为我们重构了面向大型客户的门户并将其全部转换为C#。作为其中的一部分,我们也在增加我们的单元测试覆盖率,但我在尝试模拟MediatR本身时遇到了问题。该命令做了很多事情来启动一个过程,其中一部分是发送通知。通知本身由其自己的处理程序处理,因此将接受其自己的单元测试,因此我想模拟MediatR,以便this.mediator.Send(message)调用不会真正执行任何事物。处理程序确实返回一个对象,但我们在此上下文中不关心它,因此出于所有意图和目的,我们将其视为void返回。我只想验证Send作为测试的一部分被调用了一次

c# - 将 LINQ 与 CancellationToken 一起使用的正确方法

我正在尝试使用CancellationToken编写支持取消的LINQ查询.NET框架中提供的机制。但是,尚不清楚结合取消和LINQ的正确方法是什么。使用PLINQ,可以这样写:varresultSequence=sourceSequence.AsParallel().WithCancellation(cancellationToken).Select(myExpensiveProjectionFunction).ToList();不幸的是,WithCancellation()仅适用于ParallelEnumerable-因此它不能与普通的旧LINQ查询一起使用。当然,可以使用With

c# - 等价于 ContinueWith(delegate, CancellationToken) with await continuation

我有这种情况:privateTaskLongRunningTask=/*Something*/;privatevoidDoSomethingMore(TaskpreviousTask){}publicTaskIndependentlyCancelableSuccessorTask(CancellationTokencancellationToken){returnLongRunningTask.ContinueWith(DoSomethingMore,cancellationToken);}特别是,我感兴趣的行为在MSDN'spageaboutContinuationTasks中有详细

c# - 任何区分取消和超时的方法

我有一些代码通过调用许多其他服务来验证某些数据。我并行启动所有调用,然后等到至少其中一个调用完成。如果任何请求失败,我不关心其他调用的结果。我使用HttpClient进行调用,并且我传递了一个HttpMessageHandler,它会执行大量日志记录。本质上:protectedoverrideasyncTaskSendAsync(HttpRequestMessagerequest,CancellationTokencancellationToken){HttpResponseMessageresponse=null;try{response=awaitbase.SendAsync(re

c# - Roslyn 是编译时表达式检查的正确工具吗?

我有一个工具包,其中有许多方法经常使用Expression>作为参数。有些只能是单级(o=>o.Name),而有些可以是多级(o=>o.EmployeeData.Address.Street)。我想开发一些东西(MSBuild任务?VisualStudio插件?希望是第一个)来读取所有用户的.cs文件,如果给定的参数不是属性表达式(而是类似o=>o.Contains("foo")的东西),则会出现构建错误),或者如果在只允许单级的情况下给出了多级表达式。我尝试先查看已编译的IL代码,但由于表达式树是C#编译器的“技巧”,在IL中,我所看到的只是创建表达式实例等,而我可以检查每个if仅创

c# - DelegatingHandler 应该如何进行异步调用(ASP.NET MVC Web API)?

我很乐意在调用内部处理程序的SendAsync()之前执行同步工作,并在内部处理程序通过完成完成后执行同步工作。例如:protectedoverrideTaskSendAsync(HttpRequestMessagerequest,CancellationTokencancellationToken){//dosomesyncworkbeforeinnerhandlerherevarsendTask=base.SendAsync(request,cancellationToken);returnsendTask.ContinueWith(task=>{//dosomesyncworka

c# - 如何将 task.Wait(CancellationToken) 转换为 await 语句?

因此,task.Wait()可以转化为awaittask。当然,语义是不同的,但这大致就是我将使用Waits的阻塞代码转换为使用awaits的异步代码的方式。我的问题是如何将task.Wait(CancellationToken)转换为相应的await语句? 最佳答案 await用于异步方法/委托(delegate),它们要么接受CancellationToken,因此您应该在调用它时传递一个(即awaitTask.Delay(1000,cancellationToken)),或者它们没有并且不能真正被取消(例如等待I/O结果)。但

c# - 使用 CancellationToken 取消 SQL Server 查询

我在SQLServer中有一个长时间运行的存储过程,我的用户需要能够取消它。我编写了一个小型测试应用程序,如下所示,它演示了SqlCommand.Cancel()方法工作得很好:privateSqlCommandcmd;privatevoidTestSqlServerCancelSprocExecution(){TaskFactoryf=newTaskFactory();f.StartNew(()=>{using(SqlConnectionconn=newSqlConnection("connStr")){conn.InfoMessage+=conn_InfoMessage;conn.