【发布时间】:2014-09-10 01:58:29
【问题描述】:
在已被客户端丢弃的 TCP 套接字上调用 send() 会导致内存访问冲突,因为当我运行我创建的服务器应用程序然后用来自浏览器的请求轰炸它时,它会崩溃在服务了大约 7 到 11 个请求之后。具体来说,它接受连接,然后最多停留 10 秒左右,然后 Windows 抛出“该程序已停止工作......”消息。如果我删除 send() 调用,就不会发生这样的崩溃,这让我相信 Microsoft 的 send() 不能安全地处理从另一端关闭的套接字。
我知道有多种方法可以检查套接字是否实际上已关闭,但我不想检查然后发送,因为客户端仍有可能在检查和发送之间中断。
编辑:我在“类似问题”框中注意到close() socket directly after send(): unsafe?,虽然它不太适合我的情况,但我现在想知道是否在 send() 之后快速调用 close()可能是造成问题的原因。
如果是这种情况,涉及检查然后关闭 的解决方案会起作用,因为它没有上述含义。但是,我不知道如何检查 closesocket() 是否安全。
编辑:我也可以用一种方法来检测 send() 实际上已损坏并防止整个应用程序崩溃。
编辑:我想我终于要更新这个问题了,因为我不久前就发现了这个问题,可能会有好奇的人偶然发现这个问题。事实证明,该问题与send 函数或与套接字相关的任何其他内容无关。事实上,问题出在我正在做的一件非常愚蠢的事情上:在无效指针上调用free(NULL 和类似的垃圾数据地址)。几年前,我终于从我最初使用的一个非常过时的版本更新了我的编译器,我想非常过时的标准库实现让我能够摆脱这种令人畏惧的做法,似乎什么我认为send 的问题是它的副作用。
【问题讨论】: