首页
学习
活动
专区
工具
TVP
发布

linux select函数详解

http://blog.csdn.net/lingfengtengfei/article/details/12392449 在Linux中,我们可以使用select函数实现I/O端口的复用,传递给 select...(5)structtimeval* timeout是select的超时时间,这个参数至关重要,它可以使select处于三种状态,第一,若将NULL以形参传入,即不传入时间结构,就是将select置于阻塞状态...(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() ? ? ? ? ? ?

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

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

【Oracle笔记】select for update的用法及实例解析

一、它有什么作用 select for update 是为了在查询时,避免其他用户以该表进行插入,修改或删除等操作,造成表的不一致性。...二、举几个例子: select * from t for update 会等待行锁释放之后,返回查询结果。...select * from t for update nowait 不等待行锁释放,提示锁冲突,不返回结果 select * from t for update wait 5 等待5秒,若行锁仍未释放...,则提示锁冲突,不返回结果 select * from t for update skip locked 查询返回查询结果,但忽略有行锁的记录 【使用格式】 SELECT…FOR UPDATE 语句的语法如下...:   SELECT … FOR UPDATE [OF column_list][WAIT n|NOWAIT][SKIP LOCKED]; 其中:   OF 子句用于指定即将更新的列,即锁定行上的特定列

1.3K40

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.8K20

Go select语句及其相关实例 【Go语言圣经笔记】

一个没有任何case的select语句写作select{},会永远地等待下去。 让我们回到我们的火箭发射程序。...如果多个case同时就绪时,select会随机地选择一个执行,这样来保证每一个channel都有平等的被select的机会。...这里的break语句用到了标签break,这样可以同时终结select和for两个循环;如果没有用标签就break的话只会退出内层的select循环,而外层的for循环会使之进入下一轮select循环。...main和broadcaster各自是一个goroutine实例,每一个客户端的连接都会有一个handleConn和clientWriter的goroutine。...多个goroutine共享的变量只有这些channel和net.Conn的实例,两个东西都是并发安全的。我们会在下一章中更多地讲解约束,并发安全以及goroutine中共享变量的含义。

56620

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

而此时走过来一个李四,李四这名少年也很喜欢钓鱼,但李四和张三不一样,李四左口袋装着《Linux高性能服务器编程》,右口袋装着一本《算法导论》,左手拿手机,右手拿了一根鱼竿,李四拿了钓鱼凳坐下之后,李四就开始钓鱼了...在这里额外补充一下,linux命令行中表示输入结束的快捷键是ctrl+d,当此热键被用户按下后,代表0号文件描述符写端关闭,此时读端会读到0,read会返回0值,此时进程除了输出提示信息"read file...虽然说epoll是作了改进的poll,但在接口的使用和底层实现上,epoll和poll天差地别,在linux内核2.5.44版本时,就引入了epoll接口,而现在主流的linux内核版本已经是3点几了。...模型其实也是一个struct file结构体,所以epoll_create创建epoll模型成功后,会返回一个文件描述符,而epoll_create的size参数早在内核版本2.6以后就已经被忽略了,在早期的linux...Linux、Unix、Windows 等 ---- poll缺点: (1)需要程序员自己维护一个第三方结构体数组来存储用户关心的fd及事件 (2)与select相同的是,用户仍然需要遍历整个数组来找出就绪的文件描述符

17230

Linux select 一网打尽

前言 通过阅读本文,帮你理清select的来龙去脉, 你可以从中了解到: 我们常说的select的1024限制指的是什么 ?怎么会有这样的限制? 都说select效率不高,是这样吗?为什么 ?...注:本文的所有内容均指针对 Linux Kernel, 当前使用的源码版本是 5.3.0 原型 int select (int __nfds, fd_set *__restrict __readfds,...max_fds; rcu_read_unlock(); if (n > max_fds) n = max_fds; 这个n是三类不同的fd_set中所包括的fd数值的最大值 + 1, linux...linux man中的解释如下: nfds should be set to the highest-numbered file descriptor in any of the three sets...精华所在 do_select wait queue 这里用到了Linux里一个很重要的数据结构 wait queue, 我们暂不打算展开来讲,先简单来说下其用法,比如我们在进程中read时经常要等待数据准备好

2.2K01

快速创建 Linux 实例

步骤2:购买轻量应用服务器 Linux 实例 1. 登录 轻量应用服务器控制台。 2. 单击新建,进入轻量应用服务器购买页面。...实例套餐:按照所需的服务器配置(CPU、内存、系统盘、带宽或峰值带宽、每月流量),选择一种实例套餐。 实例名称:自定义实例名称,若不填则默认使用“镜像名称-四位随机字符”。...步骤3:登录轻量应用服务器 Linux 实例 登录 轻量应用服务器控制台,在服务器列表中找到刚购买的服务器,单击登录。 Linux 实例将以免密方式登录。...登录成功后界面如下图所示: 步骤4:重置轻量应用服务器 Linux 实例密码(可选) 如果您需要使用 SSH 或者远程登录软件连接 Linux 实例,请先 重置密码 或 设置密钥。...若您使用 Ubuntu 镜像创建实例,则该实例默认禁用 root 用户名通过密码的方式登录实例。如需开启,请参考 Ubuntu 系统如何使用 root 用户登录实例?。

17210

SAP ABAP 技能:SELECTSELECT SINGLE 和 SELECT DISTINCT

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

2.7K20
领券