Pipeline 与 xargs

Pipeline与命令行參数

应用程序接收输入的两种方式:

  • 命令行參数

输入字符串被当成參数,通过int main(int argc, char **argv), 中的argv传入。或使用

以下API获取,再自己分析:

LPTSTR WINAPI GetCommandLine(void); 
  • Pipeline

指示输入内容存放在标准输入上。标准输入能够理解成一个文件,通常是字符界面终端。

也能够是一个暂时文件。

Pipeline

stdin,stdout 与 stderr

普通情况下,stdin, stdout与stderr都指向屏幕输入,即字符界面终端。但在使用管道时,

stdin与stdout并不指向终端。比如:

program1 | program2 

program1的标准输出会作为program2的标准输入,整个过程不经过终端,因此在屏幕上看

不到program1的输出。

仅仅有stderr一直指向终端。

因此假设想保证输出到终端。就要使用stderr。

读取来自Pipeline的输入

读取来自于管道的输入,事实上就是读取标准输入。

以下代码回显Pipeline输入:

int main (int argc, char **argv)
{
char buffer[64];
int nActualRead = 0; while ( true )
{
nActualRead = fread( buffer, 1, 64-1, stdin ); if ( nActualRead > 0 )
{
buffer[nActualRead] = '\0'; // Using stderr to make sure alway output to terminal.
fprintf( stderr, "%s", buffer );
}
else
{
break;
}
} return 0;
}

xargs

xargs的功能是将输入内容拆分成若干记号,再作为下一个程序的命令行參数。

xargs的通经常使使用方法是:

program1 | xargs program2

如:

ls | xargs wc 

     29      82    1834 0059441.html
37 83 1685 0059441.md
66 165 3519 total

xargs分析来自于ls的输入,组合成命令行參数,传给wc并运行。

查看xargs分析组合后的结果:

ls | xargs
0059441.html 0059441.md

即。ls | xargs wc 相当于运行 wc 0059441.html 0059441.md

vim -

指示Vim接收管道的形式为 vim -

如:

ls | vim -

Vim将读取ls的输出,并当作其的缓冲内容。

须要说明的是,”vim -“是Vim自己定义的形式,

在其他命令中”-“并不能代表标准输入。

Pipeline 与 xargs的更多相关文章

  1. [拾 得]pipe和xargs的恩怨情仇

    Photo by Joshua Sortino on Unsplash   坚持知识分享,该文章由Alopex编著, 转载请注明源地址: http://www.cnblogs.com/alopex/  ...

  2. jenkins Pipeline 使用

    说明 Jenkins pipeline 是一套插件,支持将连续输送管道实施和整合到Jenkins.Pipeline提供了一组可扩展的工具,用于通过管道DSL为代码创建简单到复杂的传送流水线.他目前支持 ...

  3. [转] Jenkins pipeline 踩坑集合

    [From] https://testerhome.com/topics/10328 前言 最近由于项目需要,接触到了Jenkins 2.0版本,其中最重要的特性就是提供了对pipeline的支持.简 ...

  4. 函数式编程之pipeline——很酷有没有

    Pipeline pipeline 管道借鉴于Unix Shell的管道操作——把若干个命令串起来,前面命令的输出成为后面命令的输入,如此完成一个流式计算.(注:管道绝对是一个伟大的发明,他的设哲学就 ...

  5. Jenkins Pipeline 部署 SpringBoot 应用

    一. 安装依赖包 yum install -y wget yum install -y gcc-c++ yum install -y zlib-devel perl-ExtUtils-MakeMake ...

  6. Jenkins使用pipeline部署服务到远程服务器

    写这篇文章是对之前搭建Jenkins做的修改和完善,让jenkins更好的为我们服务 Docker搭建Jenkins服务 使用过程中遇到的问题: 为方便部署,打算将jenkins用到的jdk11.ma ...

  7. redis大幅性能提升之使用管道(PipeLine)和批量(Batch)操作

    前段时间在做用户画像的时候,遇到了这样的一个问题,记录某一个商品的用户购买群,刚好这种需求就可以用到Redis中的Set,key作为productID,value 就是具体的customerid集合, ...

  8. Building the Testing Pipeline

    This essay is a part of my knowledge sharing session slides which are shared for development and qua ...

  9. Scrapy:为spider指定pipeline

    当一个Scrapy项目中有多个spider去爬取多个网站时,往往需要多个pipeline,这时就需要为每个spider指定其对应的pipeline. [通过程序来运行spider],可以通过修改配置s ...

随机推荐

  1. JavaIO流原理之常用字节流和字符流详解以及Buffered高效的原理

    转载请注明原文地址:http://www.cnblogs.com/ygj0930/p/5827509.html      Java的流体系十分庞大,我们来看看体系图:        这么庞大的体系里面 ...

  2. openerp学习笔记 视图继承(tree、form、search)

    支持的视图类型:form.tree.search ... 支持的定位方法:                  <notebook position="inside"> ...

  3. ACE中的参数截断工具-truncate

    变量截断工具是将类型A变量赋予类型B变量时使用,可自行判断变量是否需要截断,并且自动进行类型转换. 其全部为c实现 其入口为: ACE_Utils::truncate_cast<int> ...

  4. 〖Android〗代理与正常网络分开同步CyangenMod源码

    为了同步CyanogenMod源代码,你也学会了FQ,对吗? 通常 .repo/manifest.xml 文件有Google AOSP的Project,也有Github的Project: 访问Gith ...

  5. 转:Irrlicht 0.1引擎源码分析与研究(一)

    目录(?)[-] 主要技术特性 引擎概览 Irrlicht的窗口管理   Irrlicht引擎主要是由一个名叫Nikolaus Gebhardt奥地利人所设计,是sourceforge上的一个开源项目 ...

  6. PendingIntent传递数据注意参数RequestCode和Flag

    数据发送方: public static void notify(Context context, TxrjMessage msg) {     NotificationManager notifiM ...

  7. 【转】file_get_contents("php://input")的使用方法

    $data = file_get_contents("php://input");    php://input 是个可以访问请求的原始数据的只读流. POST 请求的情况下,最好 ...

  8. Ubuntu 12.10安装QQ2012

    [日期:2012-11-05] 在最新的Ubuntu 12.10下安装QQ2012,请根据自己的机器类型下载后按照下面的32位或64位安装说明安装. 下载网址:http://www.longene.o ...

  9. I/O Completion Ports学习

    表示还是自己看MSDN最直接,别人的介绍都是嚼剩下,有木有? IO完成端口为在多处理器系统处理多个异步IO请求提供一个高效的线程模型.当一个进程新建一个完成端口,操作系统新建一个目的为服务这些请求的队 ...

  10. libpcap详解【转】

    libpcap详解 2010-12-01 22:07 libpcap(Packet Capture Library),即数据包捕获函数库,是Unix/Linux平台下的网络数据包捕获函数库.它是一个独 ...