Cpp-Socket网络编程(九)服务器端升级为非阻塞select模型,处理更多业务

对于服务器而言,除了响应多个客户端的需求,还需要主动向推送消息,那么就提出了在select() 查询结束后如果没有其他数据可操作,服务器还可以做一些其他工作的需求,因此本篇将服务器端的select模型改造为非阻塞式的。

mac OS环境下,select的声明如下,这里第五个参数代表了查询的超时时间,即查询数据时如果等待了__restrict所定义的时间后还没有数据就立即返回。

int      select(int, fd_set * __restrict, fd_set * __restrict,
    fd_set * __restrict, struct timeval * __restrict)

改造select模型为非阻塞模型可以设置上述声明的第五个参数:

timeval t = {0, 0}; //定义一个时间变量,用于定义超时时间,这里设置为0表示立即返回
        
//select模型(nfds是指FED_SET集合中所有描述符(socket)的范围,而不是数量,即是所有文件描述符的最大值+1)
int ret = select(_sock + 1, &fdRead, &fdWrite, &fdExp, &t);

经过上述设置后,可以在服务器端增加数据查询完成后服务器端的业务逻辑,此时当服务器端有这样一个非阻塞模型时,即使没有开启多线程,服务器端也可以既处理多个客户端连接的网络程序输入请求,又可以在空闲时实现服务器的其他业务。

这样,当服务器在等待客户端连接时,或者所有客户端与服务器端结束连接时可以执行自己的业务,如果没有上述设置,服务器端会一直阻塞在select处等待客户端连接。

实验结果如图:

你可能感兴趣的:(网络编程)