小编Krz*_*ski的帖子

为什么 xargs -n 1 对于长线如此缓慢

命令生成的一行echo {,·}{,·}{,·}{,·}{,·}{,·}{,·}{,·}{,·}{,·}{,·}{,·}{,·}包含 8191 个单词,即 114687 个字符:106497 个点和 8190 个空格。

为什么拆分它| xargs -n 1需要计算时间?在我的电脑上是 8 秒。

背景故事。

与 bash 大括号扩展开玩笑,我偶然发现了一个奇特的问题。我正在检查示例问题上 bash 括号扩展的时间:在新行中打印一、二等直到 'n' (=13) 个点的字符串,避免显式循环和变量。我想出了这个有点慢的解决方案:

$ time echo {,·}{,·}{,·}{,·}{,·}{,·}{,·}{,·}{,·}{,·}{,·}{,·}{,·} | xargs -n 1 | sort -u
·
··
···
····
·····
······
·······
········
·········
··········
···········
············
·············

real    0m8.800s
user    0m0.188s
sys     0m0.748s
Run Code Online (Sandbox Code Playgroud)

我认为这是由sort性能引起的,所以我检查了一个没有排序的解决方案:

$ time echo {,·}{,·}{,·}{,·}{,·}{,·}{,·}{,·}{,·}{,·}{,·}{,·}{,·} | xargs -n 1 | awk '{if (!a[$0]) {print $0} ; a[$0]=$0}'
·
··
··· …
Run Code Online (Sandbox Code Playgroud)

xargs

1
推荐指数
1
解决办法
792
查看次数

标签 统计

xargs ×1