对libpq中运用 select()函数的理解

简介:
src/test/examples/testlibpq2.c 中,有如下一段代码:

复制代码
sock = PQsocket(conn);                                
                                
FD_ZERO(&input_mask);                                
FD_SET(sock, &input_mask);                                
                                
if (select(sock + 1, &input_mask, NULL, NULL, NULL) < 0)                                
{                                
    fprintf(stderr, "select() failed: %s\n", strerror(errno));                            
    exit_nicely(conn);                            
}
......
复制代码
经过查阅网络资料,看到解释如下:

FD_ZERO(fd_set   *fdset); 
文件描述符集合初始化

FD_SET(fd_set   *fdset); 增加一个新的文件描述符。

int   select
(int   maxfd,fd_set   *rdset,fd_set   *wrset,fd_set   *exset,struct   timeval   *timeout);    

参数maxfd 是需要监视的最大的文件描述符值+1;
 rdset, wrset, exset 
分别对应于需要检测的 可读文件描述符的集合,可写文件描述符的 集合 及 异常文件描述符的集合。
struct timeval
结构用于描述一段时间长度,
如果在这个时间内,需要监视的描述符没有事件发生则函数返回,返回值为0。

从代码的上下文看,select()并非是什么非阻塞,而是要休眠,直至操作系统发现文件描述符集合变化,
把调用 select()函数的进程唤醒。








本文转自健哥的数据花园博客园博客,原文链接:http://www.cnblogs.com/gaojian/archive/2012/07/13/2590013.html,如需转载请自行联系原作者
目录
相关文章
|
5月前
|
Oracle 关系型数据库 MySQL
MySQL语句执行报错You can‘t specify target table for update in FROM clause
MySQL语句执行报错You can‘t specify target table for update in FROM clause
49 0
|
7月前
|
Oracle 关系型数据库 MySQL
Mysql 中函数ifnull()实现oracle nvl()函数
Mysql 中函数ifnull()实现oracle nvl()函数
|
存储 关系型数据库 MySQL
【MySQL】存储过程1305 - PROCEDURE xkgl.studnet_grade does not exist
存储过程不存在,重新执行创建存储过程的命令,查看是否有该存储过程。
98 0
|
SQL Oracle 关系型数据库
MySQL 语法问题:You can‘t specify target table ‘xxx‘ for update in FROM clause. 原因及解决方法
MySQL 语法问题:You can‘t specify target table ‘xxx‘ for update in FROM clause. 原因及解决方法
194 0
|
存储 SQL 数据库

热门文章

最新文章