首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

linux select函数详解

http://blog.csdn.net/lingfengtengfei/article/details/12392449 在Linux中,我们可以使用select函数实现I/O端口的复用,传递给 select...在timeout时间内阻塞,超时时间之内有事件到来就返回了,否则在超时后不管怎样一定返回,返回值同上述。...(2)将fd加入select监控集的同时,还要再使用一个数据结构array保存放到select监控集中的fd,一是用于再select返回后,array作为源数据和fd_set进行FD_ISSET判断。...(3)可见select模型必须在select前循环array(加fd,取maxfd),select返回后循环array(FD_ISSET判断是否有时间发生)。 基本原理 ?...select()系统调用代码走读 调用顺序如下:sys_select() à core_sys_select() à do_select() à fop->poll() ? ? ? ? ? ?

5.2K20

Linux网络】select函数

select函数介绍 在Linux网络编程中,select 函数是一种非常有用的IO多路复用技术,它允许程序监视多个文件描述符(file descriptors),以等待一个或多个文件描述符变得“就绪”...#include #include #include int select(int nfds, fd_set...所谓的”准备好“状态是指:文件描述符不再是阻塞状态,可以用于某类IO操作了,包括可读,可写,发生异常三种 select函数参数介绍 nfds select函数一次会等待多个文件描述符,nfds通常为设置的最大文件描述符...函数返回值 成功时,select返回就绪的文件描述符的总数....来保存程序需要等待的文件描述符,保证调用 select 的时候readfds 和 writefds中的将如下: TCP服务器【多路复用版】 如果是一个select服务器进程,则服务器进程会不断的接收有新链接

13310
您找到你想要的搜索结果了吗?
是的
没有找到

Linux Shell函数返回值

Shell函数返回值,一般有3种方式:return,argv,echo 1) return 语句 shell函数的返回值,可以和其他语言的返回值一样,通过return语句返回。 示例: #!...获取函数的返回值通过调用函数,或者最后执行的值获得。 另外,可以直接用函数的返回值用作if的判断。 注意:return只能用来返回整数值,且和c的区别是返回为正确,其他的值为错误。...3) echo 返回值 其实在shell中,函数的返回值有一个非常安全的返回方式,即通过输出到标准输出返回。因为子进程会继承父进程的标准输出,因此,子进程的输出也就直接反应到父进程。...因此不存在上面提到的由于管道导致返回值失效的情况。 在外边只需要获取函数的返回值即可。 示例: #!...参考推荐: Shell函数返回值 Linux 之 shell 比较运算符(推荐) Linux Shell学习简单小结(推荐) SHELL学习笔记----IF条件判断,判断条件

8.9K20

Linuxselect使用陷阱

Select函数使用简单,其工作原理大家通常也知道,但是在实际的使用过程中可能并没有严格遵守,而且确实也比较难以完全遵守,除非不使用它。...Select采用一个bit表,每个fd对应表中的一个bit位,宏FD_SETSIZE为表的大小,添加到fd_set中的fd值必须小于FD_SETSIZE,否则就会越界,假设有如下一段代码: fd_set...较容易发生在服务端程序中,因为服务端程序同一时刻的连接数很容易超过默认的FD_SETSIZE值,而服务端的代码可能是使用epoll使用的,所以它本身并不会存在问题,但是程序中可能还有个客户端,比如使用了select...来实现超时连接,这个时候问题就来了,当连接数超过FD_SETSIZE时,超时连接处的select调用就发生了越界,进程就会在某个可能完全不相干的地方crash,要定位这个问题的成本是很高的,不具备一定经验...那就是尽量不使用select,而应当使用更安全的poll函数来替代,因为poll使用的数组是调用者自己维护的,完全可以保证不越界。

2K40

linux recv返回值,recv recvfrom

linux下面的定义只是将SOCKET改成int,那么在linux下面的原型是这样: int recv( int, char FAR*, int, int ); int recvfrom( int,...因为还是有点小区别,linux下面是int类型,而windows下面是unsigned int。...在成功接受到数据后,返回值都是实际接受的字节数; 套接字关闭时,返回都为0; 接受出错时,windows下面都返回SOCKET_ERROR , linux下面都返回-1, 其实你要是感兴趣可以查看SOCKET_ERROR...如果套接字为阻塞的,在系统缓冲中没有数据的情况下,都将阻塞;如果套接字为非阻塞的,在系统缓冲中没有数据的情况下,都将立即返回,返回值linux 下为-1, errno被设置为EWOULDBLOCK,在...如果内核缓冲区当时有10个字节,那么这次调用立刻返回,szRecvBuf被填充了10字节,返回值是10。

2.8K20

Linuxselect调用引发的血案

Select函数使用简单,其工作原理大家通常也知道,但是在实际的使用过程中可能并没有严格遵守,而且确实也比较难以完全遵守,除非不使用它。...Select采用一个bit表,每个fd对应表中的一个bit位,宏FD_SETSIZE为表的大小,添加到fd_set中的fd值必须小于FD_SETSIZE,否则就会越界,假设有如下一段代码: fd_set...较容易发生在服务端程序中,因为服务端程序同一时刻的连接数很容易超过默认的FD_SETSIZE值,而服务端的代码可能是使用epoll使用的,所以它本身并不会存在问题,但是程序中可能还有个客户端,比如使用了select...来实现超时连接,这个时候问题就来了,当连接数超过FD_SETSIZE时,超时连接处的select调用就发生了越界,进程就会在某个可能完全不相干的地方crash,要定位这个问题的成本是很高的,不具备一定经验...那就是尽量不使用select,而应当使用更安全的poll函数来替代,因为poll使用的数组是调用者自己维护的,完全可以保证不越界。

1.9K20

Linux】高级IO --- 多路转接,select,poll,epoll

select返回值有三种含义,大于0代表就绪的文件描述符个数,等于0代表select超时返回,小于0代表select真的是出错返回了,比如你让select监视一个根本就不存在的fd,那此时select就会出错返回...上面的工作我们可以根据select返回值来进行,当返回值大于0时,直接调用HandlerReadEvent接口处理rfds位图中就绪的读事件 2....下面是服务器的运行逻辑,这个运行逻辑写起来可比select简单多了,因为poll接口不需要在每次调用前重新设置fd到结构体中,所以写起来非常的简洁,当poll的返回值大于0时,说明有事件就绪了,那我们就执行...虽然说epoll是作了改进的poll,但在接口的使用和底层实现上,epoll和poll天差地别,在linux内核2.5.44版本时,就引入了epoll接口,而现在主流的linux内核版本已经是3点几了。...Linux、Unix、Windows 等 ---- poll缺点: (1)需要程序员自己维护一个第三方结构体数组来存储用户关心的fd及事件 (2)与select相同的是,用户仍然需要遍历整个数组来找出就绪的文件描述符

25730

Linux select 一网打尽

注:本文的所有内容均指针对 Linux Kernel, 当前使用的源码版本是 5.3.0 原型 int select (int __nfds, fd_set *__restrict __readfds,...linux man中的解释如下: nfds should be set to the highest-numbered file descriptor in any of the three sets...初始化用作参数的和用作返回值的两类fd_set if ((ret = get_fd_set(n, inp, fds.in)) || (ret = get_fd_set(n, outp, fds.out...set_fd_set(n, exp, fds.res_ex)) ret = -EFAULT; ​ 这里又多了一次内核空间到用户空间的copy, 而且我们看到返回值也是用...精华所在 do_select wait queue 这里用到了Linux里一个很重要的数据结构 wait queue, 我们暂不打算展开来讲,先简单来说下其用法,比如我们在进程中read时经常要等待数据准备好

2.3K01

SAP ABAP 技能:SELECTSELECT SINGLE 和 SELECT DISTINCT

最近开始接触一些BW历程的内容,就看到有有一部分SELECT关键词不同,但是功能类似,就想着整理一下。 SELECT 语句 SELECT 语句用于从一个数据源中查询符合条件的所有记录。...SELECT SINGLE 语句 SELECT SINGLE 语句用于从一个数据源中查询符合条件的一条记录。查询结果可以存储在一个单一变量或者一个结构体中。...SELECT DISTINCT 语句会去重,只返回不同的记录。...总结 总的来说,SELECT 用于查询多条记录,SELECT SINGLE 用于查询一条记录,SELECT DISTINCT 用于查询不同的记录。在实际开发中,应根据具体的需求选择合适的语句。...如果只需要查询一条记录,建议使用 SELECT SINGLE,可以提高查询效率和代码可读性。如果需要查询多条记录,则需要使用 SELECT

3.7K20

SELECT * 和 SELECT 全部字段

在 MySQL 查询中,SELECT * 和 SELECT 全部字段 的两种写法有不同的优缺点,以及 HAVING 子句和 WHERE 子句在查询中的异同点。...一、SELECT * 和 SELECT 全部字段 的优缺点 SELECT * 的写法 SELECT * 表示选择表中的所有字段。...SELECT 全部字段 的写法 SELECT 全部字段 表示选择表中的所有字段,但它需要手动列出每个字段。这种写法的优点是可控性更高,可以精确地选择需要的字段,从而提高查询性能和减少网络传输开销。...综上所述,SELECT * 和 SELECT 全部字段 的两种写法各有优缺点。在实际应用中,我们需要根据具体情况选择合适的写法。如果需要查询所有字段,可以使用 SELECT *。...本文详细分析了 MySQL 查询中 SELECT * 和 SELECT 全部字段 的优缺点,以及 HAVING 子句和 WHERE 子句在查询中的异同点。

2.2K30
领券