2

我正在编写几个使用 Boost.ASIO 与网络通信的应用程序。由于错误,他们中的两个突然在配置中获得了相同的端口,并且他们都成功地开始在同一个端口上侦听。这是来自netstat -na输出

TCP 0.0.0.0:40000 0.0.0.0:0监听 TCP 0.0.0.0:40000 0.0.0.0:0
监听

怎么会这样?两个不同的应用程序使用同一个 TCP 端口!

4

1 回答 1

2

如果在 Windows 上使用标志SO_REUSEADDR打开套接字,这是可能的。不幸的是,SO_REUSEADDR 标志在 Windows 上的语义与在 *nix 上的语义不同,这允许这种行为。

如果您担心另一个应用程序可能会尝试侦听您正在使用的端口,您可以使用 SO_EXCLUSIVEADDRUSE 标志。如果您可以控制所有打开套接字的应用程序,请确保您没有使用 SO_REUSEADDR 标志。

于 2013-06-10T14:59:39.783 回答