Isso é normal. Na verdade, você não pode se livrar disso sem reescrever o programa desde o início na montagem, ou escrevendo sua própria biblioteca C para usá-lo. Isso tudo é padrão para praticamente qualquer programa. Sério, você não precisa otimizar algo tão inconseqüente quanto isso. A quantidade de tempo desperdiçada ao tentar acessar arquivos inexistentes é insignificante, como você pode ver no rastreamento syscall abaixo de true
, um programa projetado apenas para retornar 0, a partir de um sistema incorporado:
root@UP-1044:~# strace -T -e trace=open true
open("/tmp/t/usr/lib/libgcc_s.so.1", O_RDONLY|O_LARGEFILE|O_CLOEXEC) = -1 ENOENT (No such file or directory) <0.000643>
open("/tmp/t/lib/libgcc_s.so.1", O_RDONLY|O_LARGEFILE|O_CLOEXEC) = -1 ENOENT (No such file or directory) <0.000861>
open("/lib/libgcc_s.so.1", O_RDONLY|O_LARGEFILE|O_CLOEXEC) = 3 <0.000208>
+++ exited with 0 +++
A quantidade de tempo desperdiçada em cada um desses syscalls parece ser menor do que um único milissegundo!