- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
在我的应用程序中,我在同一个套接字上调用了两次 shutdown
和 closesocket
函数。我知道这样做是不对的,我必须确保这些函数只被调用一次。但是,为什么这些调用中的任何一个在第二次调用时都不会失败?
如果m_Socket
的句柄是1500
,那么在shutdown
和closesocket
函数时它的值是多少被调用了吗?
shutdown(m_SocServer, 2);
closesocket(m_SocServer);
最佳答案
第一个必须区分两个不同的东西:
使用参数 2(即 SD_BOTH
)调用 shutdown
是 (1)。也就是说,您刷新所有待处理的输出缓冲区,并丢弃所有接收缓冲区。这样你就不能再读/写了。但是您仍然持有有效的套接字句柄。如果需要,您仍然可以查询/设置其选项。例如,可以对其调用 getpeername
来发现您所连接的地址。此外,根据实现情况,再次调用 shutdown
不一定会导致错误。也许它具有累积效应。
另一方面,调用 closesocket
是 (2)。一旦你调用它——你不能用那个套接字句柄做任何事情。现在无效了。
如果您的套接字的值为 1500 - 即使在调用 closesocket
之后,它仍将拥有该值。因为它只是一个变量。这就像询问在您 delete
之后指针会有什么值。
但是这个套接字值 (1500) 不再有效。您不能使用此值调用任何套接字函数。
此外,如果您同时创建另一个套接字 - 它很可能会收到相同的号码。在这里您可能会发现自己遇到了一个更严重的问题 - 在没有注意到的情况下在另一个套接字上执行操作。
对于某些人来说,在调用 closesocket
之后立即将 INVALID_SOCKET
值分配给套接字变量是一个很好的做法。
附言也许调用 shutdown
+ closesocket
不会特别因为您正在关闭另一个套接字而失败。
关于c++ - 在同一个套接字上调用 shutdown 和 closesocket 两次,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3115561/
假设我的 Linux 系统中运行着 20 个进程/deqamons,与 SHUTDOWN 相比,HALT 对我的进程/守护进程的影响有何不同 最佳答案 通常,人们使用 shutdown command
我无法理解差异。帮我看看这个区别。而ProcessPoolExecutor呢,他的行为是一样的吗? def func(task): do_something(task) tasks = [ta
在某个时候,在代码推送后不久,我们看到我们的 Web 应用程序多次重启,但没有任何日志记录表明存在任何问题。所以我找到了这篇文章:http://weblogs.asp.net/scottgu/4331
这个问题已经有答案了: Difference between shutdown and shutdownNow of Executor Service (3 个回答) 已关闭 4 年前。 以下是Exe
这个问题在这里已经有了答案: close vs shutdown socket? (9 个回答) 关闭 5 年前。 在此 MSDN 页面上: Sending and Receiving Data o
我想知道使用elasticsearch shutdown API和终止elasticsearch进程(ctrl + c)之间的区别。我实际上不以正常关闭为答案,因为我想知道发出关闭API调用时ES实际
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a software
Java 定时器调度任务:servive JVM 关闭? Timer timer = new Timer(); timer.scheduleAtFixedRate(...) JVM关闭后,调度的任务还
这个问题已经有答案了: Difference between shutdown and shutdownNow of Executor Service (3 个回答) 已关闭 5 年前。 我正在检查j
我正在 Windows 10 上的 CPython 3.7 中实现一个 Server 类,其中使用永久启动服务的 Server.serve 方法和 Server.shutdown code> 停止服务
为了避免延长等待时间,建议您在调用 awaitTermination() 之前先调用 shutdown(),因为后者不适合杀死执行者。但是,为了等待任务完成,您是否应该使用 invokeAll() 来
我正在用 Python 为老式计算机系统编写一个模拟器,在摆脱停止状态后尝试“重新启动”模拟器核心线程时,我遇到了一些抛出异常的问题。 “运行处理器”方法是一个更大类的一部分,如下所示: def ru
我有以下代码,用于在端口 8000 上运行本地 HTTP 服务器: # Omitted imports and irrelevant things for brevity. class Threade
import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util
我制作了一个程序,它会在设定的时间后关闭 PC。用户使用 2 个旋转框(一个用于小时,另一个用于分钟)输入时间,然后我将它转换为毫秒: ms = (ui->hBox->text().toInt() *
class System { public: virtual ~System() final { Shutdown(); }; virtual void Shu
看下面的代码: public void pinger() { ScheduledThreadPoolExecutor executor = new Schedule
我开发了一个小型 Java 应用程序,在其中使用 Quartz.jar 库。 但是当执行我的应用程序并调用 Quartz 时,我在控制台中收到以下错误消息: org.quartz.SchedulerE
我有 parking 系统的代码。当空格数超过 20 时,它会发送错误消息,因为 20 是空格的限制。我想在此之后尝试关闭程序。 我已尝试做您可以在 Python 中做的事情。这是: import s
我们在 RHEL (jdk 1.7.. 51) 上使用 Neo4j2.0.1 - 我们在一个同步线程上调用 GraphDatabaseService.shutDown(),并且此方法永远不会返回或引发
我是一名优秀的程序员,十分优秀!