蠢货之TaskCompletionSource 带事件的同步调用

看了这个文章 https://www.cnblogs.com/kewei/p/14339919.html

终于知道了事件的这种方式怎么来搞同步调用。看别人的文章。我copy一把。记录下。

因为拍黄片的不会调SignalR,我只好转成同步的。

[HttpGet]
public async Task<IActionResult> GetHubInfo()
{
try
{
TaskCompletionSource<string> _source = new TaskCompletionSource<string>();
var connection = new HubConnectionBuilder()
.WithUrl("http://127.0.0.1:9026/ChatHub")
.Build();
await connection.StartAsync();
using (connection.On<string>("ReceiveMessage", (s) =>
{

//这里我要copy一下别人的记录下,可能的情况。

//var tcs = new TaskCompletionSource<string>();

//var wc = new WebClient();

//wc.DownloadStringCompleted += (s, e) => {

//if (e.Error != null)

//tcs.TrySetException(e.Error);

//else if (e.Cancelled) tcs.TrySetCanceled();

//else tcs.TrySetResult(e.Result);

//};
_source.TrySetResult(s);
}))
{

TimeSpan timeout = new TimeSpan(0, 0, 5);
using var cts = new CancellationTokenSource();
cts.Token.Register(() => _source.TrySetException(new TimeoutException()), useSynchronizationContext: false);
cts.CancelAfter(timeout);
await connection.SendAsync("winFormsApp", "a", "b");

return Ok(await _source.Task);
}
}
catch (Exception ex)
{
return Ok(ex.ToString());
}
}

 

 

 

posted @   forhells  阅读(135)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
点击右上角即可分享
微信分享提示