• 关于select的一个死循环


    #include <stdio.h>
    #include <sys/types.h>
    #include <unistd.h>
    #include <sys/select.h>
    int main(int argc, char *argv[]){
        int maxfd;
        char buf[256];
        fd_set rset;
        while(1){
            FD_ZERO(&rset);
            FD_SET(STDIN_FILENO,&rset);
            select(STDIN_FILENO+1,&rset,NULL,NULL,NULL);
            if(FD_ISSET(STDIN_FILENO,&rset))
                printf("hello world!
    ");    
        }
        return 0;
    }
    

      上述代码会出现死循环的情况。

    select对fd的监听等同于对fd的缓冲区的监听。当fd的缓冲区有数据可读时,select返回。当输入任意字符,比如:“abc”,则“abc”被放在标准输入的缓冲当中,此时缓冲中有数据(abc)待读,所以select返回STDIN_FILENO就绪,程序输出“hello World!”。紧接着进入下一次循环,select重新将STDIN_FILENO加入监听的描述符集,由于刚刚的“abc”并没有被读出,所以仍在缓冲中,此时STDIN_FILENO的缓冲中仍有数据等待读,所以select又返回STDIN_FILENO可读就绪,又一次输出“hello world!”。之后循环情况类似,由于缓冲的的“待读”数据始终还在,所以每次select都直接返回STDIN_FILENO就绪,每次都输出“hello world!”,这就是造成程序死循环的原因。

  • 相关阅读:
    Node入门--事件模块
    Node入门--1--module&require
    Node入门--1-->Hello World
    文件上传(StringMVC)
    StringMVC
    Spring基础
    手动添加日期到mysql数据库
    aspectj 注解
    HandlerMapping执行过程。。。
    在考试我打
  • 原文地址:https://www.cnblogs.com/lhmily/p/3960753.html
Copyright © 2020-2023  润新知