Do tej pory Nagroda za Bezużyteczne Wykorzystaniecat
jest bardzo dobrze znana, jest też wzmianka o Bezużytecznym Wykorzystaniuecho
(nie dotyczy tego pytania). Zastanawiam się, czy powinna istnieć „ echo
Nagroda za bezużyteczne wykorzystanie w Bash”: Według niektórych nienaukowych pomiarów orurowanie wydaje się być znacznie wolniejsze niż heredoki i tustringi:
Heredocs:
for reps in 1 2 3 do time for i in {1..1000} do cat <<'END' test string END done > /dev/null done real 0m1.786s user 0m0.212s sys 0m0.332s real 0m1.817s user 0m0.232s sys 0m0.332s real 0m1.846s user 0m0.256s sys 0m0.320s
Herestrings
for reps in 1 2 3 do time for i in {1..1000} do cat <<< 'test string' done > /dev/null done real 0m1.932s user 0m0.280s sys 0m0.288s real 0m1.956s user 0m0.248s sys 0m0.348s real 0m1.968s user 0m0.268s sys 0m0.324s
Przekierowanie
for reps in 1 2 3 do time for i in {1..1000} do echo 'test string' | cat done > /dev/null done real 0m3.562s user 0m0.416s sys 0m0.548s real 0m3.924s user 0m0.384s sys 0m0.604s real 0m3.343s user 0m0.400s sys 0m0.552s
Ogólnie rzecz biorąc, heredoki i instrukcje mają mniej więcej tę samą prędkość (jest to tylko jeden zestaw danych z kilku testów), podczas gdy przekierowanie jest konsekwentnie o ponad 50% wolniejsze. Czy coś źle zrozumiałem, czy może to być ogólną zasadą dla komend czytających standardowe dane wejściowe w Bash?
cat <<END
vs. cat <<< "test string"
vs. echo "test string" | cat
lub cat <<'END'
vs. cat <<< 'test string'
vs., echo 'test string' | cat
aby powłoka wykonała taką samą liczbę rozszerzeń na łańcuchach.
$(seq $reps)
?
seq
” ;-)