No bash, touch
é um binário externo, mas echo
é um shell embutido :
$ type echo
echo is a shell builtin
$ type touch
touch is /usr/bin/touch
Como touch
é um binário externo e você invoca touch
uma vez por arquivo, o shell deve criar 300.000 instâncias de touch
, o que leva muito tempo.
echo
, no entanto, é um shell embutido, e a execução de builtins de shell não requer bifurcação. Em vez disso, o shell atual faz todas as operações e nenhum processo externo é criado; esta é a razão pela qual é muito mais rápido.
Aqui estão dois perfis das operações do shell. Você pode ver que muito tempo é gasto clonando novos processos ao usar touch
. Usar /bin/echo
em vez do shell embutido deve mostrar um resultado muito mais comparável.
Usando o toque
$ strace -c -- bash -c 'for file in a{1..10000}; do touch "$file"; done'
% time seconds usecs/call calls errors syscall
------ ----------- ----------- --------- --------- ----------------
56.20 0.030925 2 20000 10000 wait4
38.12 0.020972 2 10000 clone
4.67 0.002569 0 80006 rt_sigprocmask
0.71 0.000388 0 20008 rt_sigaction
0.27 0.000150 0 10000 rt_sigreturn
[...]
Usando eco
$ strace -c -- bash -c 'for file in b{1..10000}; do echo >> "$file"; done'
% time seconds usecs/call calls errors syscall
------ ----------- ----------- --------- --------- ----------------
34.32 0.000685 0 50000 fcntl
22.14 0.000442 0 10000 write
19.59 0.000391 0 10011 open
14.58 0.000291 0 20000 dup2
8.37 0.000167 0 20013 close
[...]