zoukankan      html  css  js  c++  java
  • 管道与popen函数与重定向

    转自:http://www.tldp.org/LDP/lpg/node12.html

    Pipes the Easy Way!

      LIBRARY FUNCTION: popen();                                                    
    
      PROTOTYPE: FILE *popen ( char *command, char *type);                          
        RETURNS: new file stream on success                                         
                 NULL on unsuccessful fork() or pipe() call                         
    
      NOTES: creates a pipe, and performs fork/exec operations using "command"

    Direction of data flow is determined by the second argument, "type". It can be "r" or "w", for "read" or "write". It cannot be both!

    popen函数相当于,创建了管道文件,通过参数
    char *type ("r" "w")来决定是从管道读取数还是 向管道写数据。

    fputs(strings[cntr], pipe_fp)将  strings  写入到管道文件中, 在管道文件读端 收到数据后后,调用
    execlp( "sort", "sort", NULL, NULL )



    
    
    int main(void)
    {
            int  cntr;
            FILE *pipe_fp;
            char *strings[MAXSTRS] = { "echo", "bravo", "alpha",
                                      "charlie", "delta"};
    
            /* Create one way pipe line with call to popen() */
            if (( pipe_fp = popen("sort", "w")) == NULL)
            {
                    perror("popen");
                    exit(1);
            }
    
            /* Processing loop */
            for(cntr=0; cntr<MAXSTRS; cntr++) {
                    fputs(strings[cntr], pipe_fp);
                    fputc('
    ', pipe_fp);
            }
    
            /* Close the pipe */
            pclose(pipe_fp);
            
            return(0);
    }
    ???
    必须在调用了
    pclose(pipe_fp); 之后。对端管道才会收到数据?

  • 相关阅读:
    C++ *和&
    leetcode 338. Bit位计数
    leetcode 216. 组合总和 III
    leetcode 40. 组合总和 II
    c++ vector 常用函数
    leetcode 491. 递增子序列
    leetcode 441. 排列硬币
    leetcode 258. 各位相加
    leetcode 415. 字符串相加
    leetcode 67. 二进制求和
  • 原文地址:https://www.cnblogs.com/zhangxuan/p/6282810.html
Copyright © 2011-2022 走看看