- Quelle est la différence entre les voies?
de bash manpage:
eval [arg ...]
The args are read and concatenated together into a single com‐
mand. This command is then read and executed by the shell, and
its exit status is returned as the value of eval. If there are
no args, or only null arguments, eval returns 0.
source filename [arguments]
Read and execute commands from filename in the current shell
environment and return the exit status of the last command exe‐
cuted from filename. If filename does not contain a slash, file
names in PATH are used to find the directory containing file‐
name. The file searched for in PATH need not be executable.
When bash is not in posix mode, the current directory is
searched if no file is found in PATH. If the sourcepath option
to the shopt builtin command is turned off, the PATH is not
searched. If any arguments are supplied, they become the posi‐
tional parameters when filename is executed. Otherwise the
positional parameters are unchanged. The return status is the
status of the last command exited within the script (0 if no
commands are executed), and false if filename is not found or
cannot be read.
Il n'y a aucune différence entre les deux façons.
Il n'y a qu'une seule note: evalconcaténé tous ses arguments, qui est ensuite exécuté comme une seule commande. sourcelit le contenu d'un fichier et l'exécute. evalne peut construire des commandes qu'à partir de ses arguments, non stdin. Vous ne pouvez donc pas faire comme ça:
printf "ls" | eval
- Quel est le plus préféré?
Votre exemple fournit le même résultat, mais le but de evalet sourceest différent. sourceest généralement utilisé pour fournir une bibliothèque pour d'autres scripts, tandis que evaln'est utilisé que pour évaluer les commandes. Vous devez éviter d'utiliser evalsi possible, car il n'y a aucune garantie que la chaîne évaluée est propre; nous devons faire quelques vérifications de santé mentale, en utilisant à la subshellplace.
- Si nous exécutons certaines commandes dans () ou {}, laquelle est la plus préférée?
Lorsque vous exécutez des commandes de séquences à l'intérieur d'une accolade { }, toutes les commandes sont exécutées dans le shell actuel , au lieu d'une sous- coque (ce qui est le cas si vous exécutez entre parenthèses (voir référence bash )).
L'utilisation subshell ( )utilise plus de ressources, mais votre environnement actuel n'est pas affecté. L'utilisation { }exécute toutes les commandes du shell actuel, de sorte que votre environnement est affecté. Selon votre objectif, vous pouvez en choisir un.