Socket异步发送的同步控制
在网络通信中,我们使用Socket异步发送数据,但在客户端,往往是需要等待服务器的返回结果后(握手过程)再往下执行,这就涉及到同步控制了,在多次的实现中,使用AutoResetEvent,实现不,即有时候发现,Socket数据返回比阻塞的UI线程快,不知道是Socket的优先级别高,还是什么原因。总之,这个同步控制是失败的。后来经研究,想到了解决办法,只要发送线程和接收线程同时对ThreadSemaphore进行操作,发送数据时调用Wait方法,收到Socket返回的数据时调用Set方法,问题解决。对于信号量的同步控制有很多场合的应该,不同的场合可以设计不同的实现。看了很多的实现,都是需求相对复杂的,而我的需求就是阻塞UI线程,等待服务器返回结果后再往下执行,所以只能参考别的实现,自己设计(下面程序没有经过测试,只是一个即时设计)。
public class ThreadSemaphore
{
bool m_isSocketReturn;
public bool Wait(int timeout)
{
lock(this)
{
if (!m_isSocketReturn && !Monitor.Wait(this, timeout)
retun m_isSocketReturn;
}
retun m_isSocketReturn;
}
pulic void Set()
{
lock(this)
{
m_isSocketReturn = true;
Monitor.PulseAll(this);
}
}
}
【推荐】还在用 ECharts 开发大屏?试试这款永久免费的开源 BI 工具!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步