构造参数列表并运行命令。
xargs [ -p ] [ -t ] [ -e [ EOFString ] ] [ -E EOFString ] [ -i [ ReplaceString ] ] [ -I ReplaceString ] [ -l [ Number ] ] [ -L Number ] [ -n Number [ -x ] ] [ -s Size ] [ Command [ Argument ... ] ]
注: 不要在小写标志和参数之间放置空格。
生成的命令行长度是 Command 和每个作为字符串对待的 Argument(包括每个字符串的空字节 终结符)的大小的总和(以字节为单位)。xargs 命令限制命令行的长度。 当构造的命令行运行时,组合的 Argument 和环境列表 不能超出 ARG_MAX 字节。在这个约束下,如果 不指定 -n 或 -s 标志,缺省命令行长度 至少是由 LINE_MAX 指定的值。
该命令返回下列退出值:
0 | 所有 Command 参数的调用 都返回退出状态 0。 |
1-125 | 不能汇编满足指定需求的命令行, 一个或多个 Command 参数的调用 返回一个非零的退出状态,或发生一些其它的错误。 |
126 | Command 已找到但不能被调用。 |
127 | 找不到 Command。 |
如果不能汇编满足指定需求的命令行, 则不能调用这个命令,命令的调用被一个信号终止,或以退出状态 255 退出。xargs 命令将写一条诊断消息并 退出而不处理任何保留的输入。
xargs lint -a <cfiles
如果 cfiles 文件包含下面的 文本:
main.c readit.c gettoken.c putobj.c
xargs 命令就构造并运行 下面的命令:
lint -a main.c readit.c gettoken.c putobj.c
如果 cfiles 文件包含的文件名比在单一 shell 命令行上能处理的文件名(最多 LINE_MAX)要多,xargs 命令会用后者运行 lint 命令。然后它使用余下的文件名构造并运 行另一个 lint 命令。 根据在 cfiles 文件中列出的名称, 命令看起来可能类似于如下所示的内容:
lint -a main.c readit.c gettoken.c . . . lint -a getisx.c getprp.c getpid.c . . . lint -a fltadd.c fltmult.c fltdiv.c . . .
该命令序列同用所有的文件名运行 lint 命令一次不完全一样。lint 命令检查文件之间的交叉参考。然而,在这个示例中, 它不能在 main.c 和 fltadd.c 文件之间,或任意两个在分开 的命令行上列出的文件之间进行检查。
由于这个原因, 仅当所有的文件名都在一行上列出时,才可能运行命令。要将这个指定 到 xargs命令,通过输入以下命令使用 -x 标志:
diff starting chap1 diff concepts chap2 diff writing chap3
-t 标志使 在运行 xargs 命令前显示每个命令, 这样您可以看到正在发生的事件。<<EOF 和 EOF 模式匹配字符定义 一个 here document, 它把在结尾行之前输入的文本用作对 xargs 命令的标准输入。
mv chap1 chap1.old mv chap2 chap2.old mv chap3 chap3.old
会显示一些类似于下面的内容:
ar r lib.a chap1 ?... ar r lib.a chap2 ?... ar r lib.a chap3 ?...
ls | xargs -n6 | xargs -I{} echo {} - some files in the directory
如果当前目录 包含从 chap1 到 chap10 的文件,构造的输出将会是下列内容:
chap1 chap2 chap3 chap4 chap5 chap6 - some files in the directory chap7 chap8 chap9 chap10 - some file in the directory
/usr/bin/xargs | 包含 xargs 命令。 |
ar 命令、diff 命 令、echo 命 令、ksh 命 令、lint 命 令、ls 命 令、mv 命令。
《AIX 5L V5.2 系统用户指南:操作系统与设备》中的『shell 概述』和『命令概述』。
AIX 5L Version 5.2 General Programming Concepts: Writing and Debugging Programs 中的 Input and Output Handling Programmer's Overview。