最近写程序遇到一个问题,使用httpListener写服务的时候,需要对客户端消息进行顺序处理,即处理完一个再处理下一个,然后再开发过程当中,我使用lock对过程代码进行了锁,旨在让程序顺序处理。在lock介绍时,都是说当一个线程在使用lock中的代码,另一个程序需要顺序等待,只有等第一个执行完成后,释放lock资源时,才能进入,但在实际开发过程中,是多个线程同时遇到lock时,会排队顺序进入其中执行,而不会等待上一个是否处理完成,相当于限流,但不是阻塞,这个导致中间代码逻辑处理比较耗时,而逻辑又承上启下的话,后续处理和自己理想中的不一样,而如果后一个在lock中去等待上一个执行完成的话,会导致所有程序都进行不下去,在外层加一个等待也是一样的效果,因为我在外层已经排过一次序了,所以我这里是双层锁,一个是锁客户端,一个是锁消息,发现的不理想,所以我现在的解决办法是在锁方法里加一个变量,在将要进入时,通过判断变量判断这段代码是否正在被执行,如果正在执行,则放弃当前的连接,这样会导致有些客户端会接收超时并重新发送数据,就是所谓的数据丢失。回头我想再试试在客户端接收数据入口处直接去处理,判断是否正在处理消息,如果正在处理消息,则排序等待,否则再顺序进入,回头就去测试一下,如果可以行得通的话,那么就不用丢弃数据了。回头如果有测试结果再继续发布,如果大家也遇到这样的问题,可以注意一下,或者如果有好的建议,欢迎讨论。
相关推荐
没什么本事7 小时前
关于C# panel 添加lable问题 -- 明确X和Y 位置错误火星papa8 小时前
C# 实现平滑流畅的进度条ProgressBar游乐码10 小时前
UnityGUI(五)GUI控件综合使用程序leo源10 小时前
C语言知识总结烛阴11 小时前
TEngine 入门系列(二):三件套环境搭建 -- Unity + TEngine + AI 助手The Shio15 小时前
OptiByte 操练场:面向 IoT/嵌入式的协议可视化调试工具龙侠九重天17 小时前
C# 调用 TensorFlow:迁移学习与模型推理实战指南我是唐青枫18 小时前
C#.NET YARP 认证授权实战:在网关层统一接入 JWT程序leo源18 小时前
Linux深度理解白菜上路19 小时前
C# .net 生成版本号自动变更