Linux中xargs命令的使用方法

  介绍

这期内容当中小编将会给大家带来有关Linux中xargs命令的使用方法,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

Linux命令可以从两个地方读取要处理的内容,一个是通过命令行参数,一个是标准输入,例如猫,grep就是这样的命令,举个例子:

echo  & # 39;主要# 39;,|,cat  test.cpp

这种情况下猫会输出test.cpp的内容,而不是& # 39;主要# 39;字符串,如果测试。cpp不存在则猫命令报告该文件不存在,并不会尝试从标准输入中读取.echo & # 39;主要# 39;|会通过管道将回声的标准输出(也就是字符串& # 39;主要# 39;)导入到猫的标准输入,也就是说此猫时的标准输入中是有内容的,其内容就是字符串& # 39;主要# 39;但是上面的内容中猫不会从
它的标准输入中读入要处理的内容。(注:标准输入是有一个缓冲区的,就像我们在程序中使用scanf函数从标准输入中读取一样,实际上是从标准输入的缓冲区中读取的)。其实基本上linux的命令中很多的命令的设计是先从命令行参数中获取参数,然后从标准输入中读取,反映才程序上,命令行参数是通过主要函数的int主要(int命令行参数个数,char * argv[])函数参数获得的,而标准输入则是通过标准输入函数例如C语言中的scanf读取到的。他们获取的地方是不一样的,例如:

echo  & # 39;主要# 39;,|,猫

这条命令会中猫会从其标准输入中读取内容并处理,也就是会输出& # 39;主要# 39;字符串.echo命令将其标准输出的内容& # 39;主要# 39;通过管道定向到猫的标准输出中。

猫如果仅仅输入猫并回车,则该程序会等待输入,我们需要从键盘输入要处理的内容给猫,此时猫也是从标准输入中得到要处理的内容的,因为我们的猫命令行中也没有指定要处理的文件名。大多数命令有一个参数,安康;如果直接在命令的最后指定之处;则表示从标准输入中读取,

例如:

echo  & # 39;主要# 39;,|,cat ——

这样也是可行的,会显示& # 39;主要# 39;字符串,同样输入猫——直接回车与输入猫直接回车的效果也一样,但是如果这样呢:

echo  & # 39;主要# 39;,|,cat  test.cpp  -

同时指定测试。cpp和——参数,此猫时程序还是会显示测试。cpp的内容。但是有一个程序的策略则不同,它是grep,例如:

echo  & # 39;主要# 39;,|,grep  & # 39;主要# 39;,test.cpp ——

该命令的输出结果是:

test.cpp: int 主要()   (standard 输入):主要

此时grep会同时处理标准输入和文件测试。cpp中的内容,也就是说会在标准输入中搜索& # 39;主要# 39;也会在文件测试。cpp(该文件名从grep命令行参数中获得)中搜索& # 39;主要# 39;。也就是说当命令行中测试。cpp和——两个参数同时存在的时候,不同的程序处理不同。我们看到了猫与grep处理就不同。但是有一点是一样的,首先在命令行中查找要处理的内容的来源(是从文件还是从标准输入,还是都有),如果在命令行中找不到与要处理的内容的来源相关的参数则默认从标准
输入中读取要处理的内容了。

另外很多程序是不处理标准输入的,例如杀死,rm这些程序如果命令行参数中没有指定要处理的内容则不会默认从标准输入中读取。所以:

echo  & # 39; 516 & # 39;, |,杀了

这种命里是不能执行的。

echo  & # 39;测试# 39;,|,rm  - f

这种也是没有效果的。

这两个命令只接受命令行参数中指定的处理内容,不从标准输入中获取处理内容。想想也很正常,杀死是结束进程,rm是删除文件,如果要结束的进程pid和要删除的文件名需要
从标准输入中读取,这个也很怪异吧。但是像猫与grep这些文字处理工具从标准输入中读取待处理的内容则很自然。

但是有时候我们的脚本却需要呼应& # 39;516 & # 39;|杀死这样的效果,例如ps ef | grep & # 39; ddd # 39;|杀死这样的效果,筛选出符合某条件的进程pid然后结束。这种需求对于我们来说是理所当然而且是很常见的,那么应该怎样达到这样的效果呢。有几个解决办法:

<强> 1。通过

kill “ps  -ef  |, grep  & # 39; ddd # 39;”

#这种形式,这个时候实际上等同于拼接字符串得到的命令,其效果类似于,

Linux中xargs命令的使用方法