最近写程序遇到一个问题,使用httpListener写服务的时候,需要对客户端消息进行顺序处理,即处理完一个再处理下一个,然后再开发过程当中,我使用lock对过程代码进行了锁,旨在让程序顺序处理。在lock介绍时,都是说当一个线程在使用lock中的代码,另一个程序需要顺序等待,只有等第一个执行完成后,释放lock资源时,才能进入,但在实际开发过程中,是多个线程同时遇到lock时,会排队顺序进入其中执行,而不会等待上一个是否处理完成,相当于限流,但不是阻塞,这个导致中间代码逻辑处理比较耗时,而逻辑又承上启下的话,后续处理和自己理想中的不一样,而如果后一个在lock中去等待上一个执行完成的话,会导致所有程序都进行不下去,在外层加一个等待也是一样的效果,因为我在外层已经排过一次序了,所以我这里是双层锁,一个是锁客户端,一个是锁消息,发现的不理想,所以我现在的解决办法是在锁方法里加一个变量,在将要进入时,通过判断变量判断这段代码是否正在被执行,如果正在执行,则放弃当前的连接,这样会导致有些客户端会接收超时并重新发送数据,就是所谓的数据丢失。回头我想再试试在客户端接收数据入口处直接去处理,判断是否正在处理消息,如果正在处理消息,则排序等待,否则再顺序进入,回头就去测试一下,如果可以行得通的话,那么就不用丢弃数据了。回头如果有测试结果再继续发布,如果大家也遇到这样的问题,可以注意一下,或者如果有好的建议,欢迎讨论。
相关推荐
mudtools7 小时前
.NET驾驭Word之力:理解Word对象模型核心 (Application, Document, Range)大飞pkz13 小时前
【设计模式】C#反射实现抽象工厂模式唐青枫15 小时前
从入门到进阶:C#.NET Stopwatch 计时与性能测量全攻略未来之窗软件服务1 天前
幽冥大陆(二)RDIFSDK 接口文档:布草洗涤厂高效运营的技术桥梁C#—东方仙盟1uther1 天前
Unity核心概念⑨:Screen阿幸软件杂货间1 天前
Office转PDF转换器v1.0.pysali-tec1 天前
C# 基于halcon的视觉工作流-章34-环状测量Tiger_shl1 天前
【层面一】C#语言基础和核心语法-02(反射/委托/事件)mudtools1 天前
.NET驾驭Word之力:COM组件二次开发全攻略之连接Word与创建你的第一个自动化文档王维志1 天前
LiteDB详解