最近写程序遇到一个问题,使用httpListener写服务的时候,需要对客户端消息进行顺序处理,即处理完一个再处理下一个,然后再开发过程当中,我使用lock对过程代码进行了锁,旨在让程序顺序处理。在lock介绍时,都是说当一个线程在使用lock中的代码,另一个程序需要顺序等待,只有等第一个执行完成后,释放lock资源时,才能进入,但在实际开发过程中,是多个线程同时遇到lock时,会排队顺序进入其中执行,而不会等待上一个是否处理完成,相当于限流,但不是阻塞,这个导致中间代码逻辑处理比较耗时,而逻辑又承上启下的话,后续处理和自己理想中的不一样,而如果后一个在lock中去等待上一个执行完成的话,会导致所有程序都进行不下去,在外层加一个等待也是一样的效果,因为我在外层已经排过一次序了,所以我这里是双层锁,一个是锁客户端,一个是锁消息,发现的不理想,所以我现在的解决办法是在锁方法里加一个变量,在将要进入时,通过判断变量判断这段代码是否正在被执行,如果正在执行,则放弃当前的连接,这样会导致有些客户端会接收超时并重新发送数据,就是所谓的数据丢失。回头我想再试试在客户端接收数据入口处直接去处理,判断是否正在处理消息,如果正在处理消息,则排序等待,否则再顺序进入,回头就去测试一下,如果可以行得通的话,那么就不用丢弃数据了。回头如果有测试结果再继续发布,如果大家也遇到这样的问题,可以注意一下,或者如果有好的建议,欢迎讨论。
相关推荐
hixiong1237 小时前
C# TensorRT部署RF-DETR目标检测&分割模型神仙别闹13 小时前
基于C# 利用工程活动图 AOE 网设计算法游乐码13 小时前
c#迭代器海盗123413 小时前
C# OPC UA客户端开发实战asdzx6713 小时前
使用 C# 从 URL 下载 Word 文档xiaoshuaishuai814 小时前
C# DeepSeek V4 与 V3对比游乐码16 小时前
c#特殊语法.NET修仙日记16 小时前
2026 .NET 面试八股文:高频题 + 答案 + 原理(高级核心篇)唐青枫18 小时前
终于不用手搓两级缓存了!C#.NET HybridCache 详解:L1 L2、标签失效与防击穿实战hixiong1231 天前
C# OpenvinoSharp使用DINOv2模型进行图像相似度计算