-
FFIVE
argc 为命令行参数的数量,char **argv为命令行参数的指针 输出结果是T1 **argv返回当前参数的第一个字符,当它不等于字符a时,打印当前参数,argv++将参数指针自增 while(**argv++!='a') 就是判断当前参数的第一个字符是否等于字符a
-
慕姐4208626
linux select函数详解在Linux中,我们可以使用select函数实现I/O端口的复用,传递给 select函数的参数会告诉内核:•我们所关心的文件描述符•对每个描述符,我们所关心的状态。(我们是要想从一个文件描述符中读或者写,还是关注一个描述符中是否出现异常)•我们要等待多长时间。(我们可以等待无限长的时间,等待固定的一段时间,或者根本就不等待)从 select函数返回后,内核告诉我们一下信息:•对我们的要求已经做好准备的描述符的个数•对于三种条件哪些描述符已经做好准备.(读,写,异常)有了这些返回信息,我们可以调用合适的I/O函数(通常是 read 或 write),并且这些函数不会再阻塞.#include <sys/select.h>int select(int maxfdp1, fd_set *readset, fd_set *writeset, fd_set *exceptset,struct timeval *timeout);返回:做好准备的文件描述符的个数,超时为0,错误为 -1.首先我们先看一下最后一个参数。它指明我们要等待的时间:struct timeval{long tv_sec; /*秒 */long tv_usec; /*微秒 */}有三种情况:timeout == NULL 等待无限长的时间。等待可以被一个信号中断。当有一个描述符做好准备或者是捕获到一个信号时函数会返回。如果捕获到一个信号, select函数将返回 -1,并将变量 erro设为 EINTR。timeout->tv_sec == 0 &&timeout->tv_usec == 0不等待,直接返回。加入描述符集的描述符都会被测试,并且返回满足要求的描述符的个数。这种方法通过轮询,无阻塞地获得了多个文件描述符状态。timeout->tv_sec !=0 ||timeout->tv_usec!= 0 等待指定的时间。当有描述符符合条件或者超过超时时间的话,函数返回。在超时时间即将用完但又没有描述符合条件的话,返回 0。对于第一种情况,等待也会被信号所中断。
-
万千封印
--建立分割函数Create FUNCTION [dbo].[SplitToTable](@SplitString nvarchar(max),@Separator nvarchar(10)=' ')RETURNS @SplitStringsTable TABLE([id] int identity(1,1),[value] nvarchar(max))ASBEGINDECLARE @CurrentIndex int;DECLARE @NextIndex int;DECLARE @ReturnText nvarchar(max);SELECT @CurrentIndex=1;WHILE(@CurrentIndex<=len(@SplitString))BEGINSELECT @NextIndex=charindex(@Separator,@SplitString,@CurrentIndex);IF(@NextIndex=0 OR @NextIndex IS NULL)SELECT @NextIndex=len(@SplitString)+1;SELECT @ReturnText=substring(@SplitString,@CurrentIndex,@NextIndex-@CurrentIndex);INSERT INTO @SplitStringsTable([value]) VALUES(@ReturnText);SELECT @CurrentIndex=@NextIndex+1;ENDRETURN;ENDgoselect * from [dbo].[SplitToTable]('1081||04401453|||8038000823|||A36490|803800|720402||1|17.90|0|0|0|0|0||||0||||||||||||||||0.90|17.00||','|')where id=3