gpt4 book ai didi

C++ 套接字 Send() 线程安全

转载 作者:塔克拉玛干 更新时间:2023-11-03 02:13:32 24 4
gpt4 key购买 nike

我正在为最多 1000 个客户端编写套接字服务器,服务器是关于我的游戏,我使用非阻塞套接字和大约 10 个同时从不同套接字接收数据的线程(第一个线程从 0-100 接收,第二个从101-200 等等..)

但是如果线程1要向所有1000个客户端发送数据,线程2也想同时向所有1000个客户端发送数据,这样安全吗?数据是否有可能在另一方(客户端)被弄乱?

如果是,我想唯一可能发生的问题是有时客户端会收到 2 个或 10 个数据包作为 1 个数据包,对吗?如果是,是否有任何解决方案:(

最佳答案

处理多个套接字的通常模式是使用专用线程轮询 I/O 事件 select(2) , poll(2) , 或更好 kqueue(2) epoll(4) (取决于平台)充当套接字事件调度程序。套接字通常以非阻塞模式处理。然后可能有线程池对事件使用react,并直接或通过较低级别的缓冲区/队列进行读写。

各种技术都适用于此 - 从队列到事件订阅白板。 I/O 级别的多路复用接受/读取/写入/EOF 以及应用程序级别的事件仲裁变得棘手。几个库,如 <b>libevent</b> <b>boost::asio</b> 帮助构建较低级别(ACE 库也在这个领域,但我不想向任何人推荐它)。您必须自己提出应用程序级协议(protocol)和状态机(同样 <b>boost::statechart</b> 可能会有帮助)。

一些很好的链接可以让您更好地了解您所面对的问题(这可能是他们在 SO 上被提及的第一百万次):

很抱歉没有提供具体的解决方案,但这是一个非常广泛的设计问题,大多数决策在很大程度上取决于上下文(虽然很有趣)。希望这能有所帮助。

关于C++ 套接字 Send() 线程安全,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3235424/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com