c# - Non-Blocking IO是如何实现的?

标签 c# java sockets nonblocking

在 Java 或 C# 或其他一些语言中,有非阻塞 IO 设施,例如,用于套接字。

所以我可以将我的回调函数提供给非阻塞 IO,一旦非阻塞 IO 收到任何东西,它就会调用我的回调。

我想知道它们是如何实现的。如果我在幕后创建非阻塞 IO,Java 或 C# 是否只是为它们创建后台线程?或者底层操作系统对它们有原生支持?

最佳答案

在 Windows 上,底层操作系统支持非阻塞 I/O,Microsoft 的 CLR 利用了这一点。其他 CLR 实现(单声道)可能也一样,但我不确定。在 Microsoft CLR 上执行异步 I/O 时,挂起的异步 I/O 操作与等待这些 I/O 操作完成的线程(或至少托管线程)之间没有一对一的关联。

参见 http://msdn.microsoft.com/en-us/library/windows/desktop/aa365683(v=vs.85).aspx有关 Win32 层详细信息的一些详细信息。还有关于 I/O 完成端口的信息:http://msdn.microsoft.com/en-us/library/aa365198(VS.85).aspx

我的理解是这样的:

  1. 我在某个应用程序线程上开始异步 I/O 操作。
  2. 如果还没有,将创建一个队列(好吧,实际上是一个称为 I/O 完成端口的内核级结构,它与我的应用程序内核空间中的一个队列相关联)。在 .NET 世界中,一个称为 I/O 完成端口线程的特别指定线程将开始等待该队列上的 I/O 完成通知。这里需要注意的重要一点是,我可以发出任意数量的异步 I/O 请求,而无需增加 I/O 完成端口的数量。
  3. 当 I/O 完成时,操作系统将通过在队列中加入 I/O 完成消息来通知应用程序。然后,I/O 完成端口线程将通过在我的 .NET 应用程序中调用 I/O 完成回调来处理该消息。同时,如果其他 I/O 完成,其结果将排在当前正在处理的结果之后。

以上注意事项:

  1. 我确信我有一部分是错的,但我相信它的整体要点是正确的。 Eric 或其他人可以进来纠正我的错误。

  2. 在 .NET 中有多个 I/O 完成端口线程。我不知道如何在各种 I/O 完成端口之间分配异步 I/O 请求。这可能是操作系统功能(其中 I/O 可能会在应用程序打开的任何端口上返回)。

对于 Java,我确信它取决于 JVM 实现和特定的操作系统。我对它的了解还不够深入,无法推测。

编辑:历史更新,更多细节here

关于c# - Non-Blocking IO是如何实现的?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10538708/

相关文章:

c# - 在构造函数末尾抛出异常是否会损坏对象?

c# - HttpWebRequest.GetResponse() 与 GetResponseAsync() 中的超时行为

c# - 在循环位字段中设置位范围

java - 套接字不断关闭

java - 监听时在 Socket 上发送

c# - 将 ApplicaitonSettings 放在分层 mvc 项目中的什么位置?

java - OSGI - 缺少导入的包=org.apache.commons.collections

java - 使用 JAXB 解码嵌套对象

java - 将数组中字符串的递增数字连接起来

c# - 获取远程套接字端点的 IP 地址