Socket编程 | TCP服务器IO模型之非阻塞轮询-4

1. 引言

前面的文章已经讲了如何搭建一个多线程/多进程的服务器模型,可以支持多个客户端同时连接服务器, 本篇来实现一种单进程的非阻塞轮询机制的服务器模型。

之前文章连接:

Socket编程 | TCP编程基本流程和API详解-1

Socket编程 | TCP服务端阻塞IO模型(多线程)-2

Socket编程 | TCP服务器IO模型之并发阻塞(多进程实现)-3

2. 概念理解

之前多线程/多进程服务器模型都是基于阻塞IO的机制实现的,本次测试以非阻塞IO为基础,服务端轮询的检测客户端的连接,关于阻塞与非阻塞的概念解释如下:

2.1 阻塞I/O模型:

进程会一直阻塞,直到数据拷贝完成。

应用程序调用一个IO函数,导致应用程序阻塞,等待数据准备好。 如果数据没有准备好,一直等待….数据准备好了,从内核拷贝到用户空间,IO函数返回成功指示。

当调用recv()/read()函数时,系统首先查是否有准备好的数据。如果数据没有准备好,那么系统就处于等待状态。当数据准备好后,将数据从系统缓冲区复制到用户空间,然后该函数返回。

当使用socket()函数创建套接字时,默认的套接字都是阻塞的。并不是

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Engineer-Jaylen_Sun

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值