• shell 管道 与 mkfifo


    管道是一种通信机制,用于进程间的通信(也可通过socket进行网络通信),表现出来的形式将前面的每一个进程的输出,直接作为下一个进程的输入
    管道命令仅能处理stdout,而error则会忽略

    顺序执行多条命令,可以用分号;
    cmd1;cmd2;cmd3
    条件执行多条命令,使用&&(前一个命令执行成功,即$?=0时,执行下一条命令,否则不执行)和||(前一个命令执行失败,既$?≠0时,执行下一条命令)
    cmd1&&cmd2||cmd3
    $?:上一次命令的返回结果,0为执行成功,不为0则为执行失败

    常用管道命令
    cut、grep、sort、wc、uniq
    tee:重定向,既能在屏幕输出,又能保存到文件中
    tr、col、join、paste、expand、split

    |(竖线)为管道,是两个进程之间的通信通道
    例如:ls|grep txt
    ls和grep由|分开,管道创建了程序之间的通信通道,将ls的输出作为输入传给grep

    由mkfifo创建出来的就是一个命名管道
    例如:mkfifo pipe2
    pipe2就是一个命名管道

    可以将输出信道化到不同终端、
    例如:
    在第一个终端执行
    ls > pipe2
    在第二个终端执行
    cat < pipe2(或cat pipe2,是取一次。cat < pipe2是持续输入,只要有内容传到pipe2中,就会有内容输出)
    pipe2更像是一个临时存储的地方,使用cat pipe2取过内容之后,再执行cat pipe2 ,则不会有显示

    命名管道可以像正常文件一样访问,在文档类型可以看到为p
    ll pipe2
    prw-r--r-- 1 root root 0 Oct 16 14:53 pipe2

    Ps: 当命令不支持管道时可以使用 xargs

    xargs可以将stdin中以空格或换行符进行分隔的数据,形成以空格分隔的参数(arguments),传递给其他命令
    xargs是给其他命令传递参数的一个过滤器,是构建单行命令的重要组件之一

  • 相关阅读:
    C++ Primer 笔记——标准库类型string
    Windows文件系统
    c++数组
    B+树
    简单搭建FastDFS分布式文件系统(简单易懂)
    什么是分布式系统(通俗易懂)
    对List中每个对象元素按时间顺序排序
    java23种设计模式之一: 策略模式
    微信app支付java后台流程、原理分析及nei网穿透
    quartz多任务调度+spring 实现
  • 原文地址:https://www.cnblogs.com/yxfcnbg/p/13812525.html
Copyright © 2020-2023  润新知