Partager via


Switch-Process

Sur Linux et macOS, l’applet de commande appelle la fonction execv() pour fournir un comportement similaire à celui des interpréteurs de commandes POSIX.

Syntaxe

Switch-Process
      [[-WithCommand] <String[]>]
      [<CommonParameters>]

Description

Certaines commandes Unix natives s’exécutent pour exécuter quelque chose (comme ssh) et utiliser la commande intégrée bashexec pour générer un nouveau processus qui remplace celui actuel. Par défaut, exec n’est pas une commande valide dans PowerShell. Cela affecte certains scripts connus tels que copy-ssh-id et certaines sous-commandes d’AzCLI.

L’applet de commande Switch-Process appelle la fonction execv() native pour fournir un comportement similaire à celui des interpréteurs de commandes POSIX. Cette applet de commande et son alias, exec, ont été ajoutés dans PowerShell 7.3.0.

PowerShell 7.3.1 a modifié l’alias de exec en fonction qui encapsule Switch-Process. La fonction vous permet de passer des paramètres à la commande native susceptible d’être liée par erreur au paramètre WithCommand.

Cette applet de commande est disponible uniquement pour les systèmes non-Windows.

Exemples

Exemple 1 : Exécuter une commande qui dépend de « exec »

Cet exemple suppose que PowerShell est l’interpréteur de commandes par défaut sur un système non Windows. ssh-copy-id est un script bash populaire pour déployer des clés publiques sur des machines cibles pour l’authentification basée sur des clés. Le script dépend de la commande bash, exec.

ssh-copy-id user@host

Une fois la fonctionnalité PSExec activée, le script ssh-copy-id réussit.

Paramètres

-WithCommand

Spécifie l’exécutable natif (et tous les paramètres) à exécuter. Toutes les valeurs supplémentaires passées en tant qu’arguments sont passées en tant que tableau de chaînes à exécuter avec la première commande.

La commande cible doit être un exécutable natif, et non une commande PowerShell.

Type:String[]
Position:0
Valeur par défaut:None
Obligatoire:False
Accepter l'entrée de pipeline:False
Accepter les caractères génériques:False

Entrées

String[]

Sorties

Object

Notes

L’applet de commande Switch-Process a été créée pour fournir exec compatibilité est d’autres shells POSIX. Dans des conditions normales, l’applet de commande n’est pas destinée à être utilisée dans les scripts PowerShell. Switch-Process n’a pas de parité de fonctionnalité avec la fonction exec intégrée dans les interpréteurs de commandes POSIX, comme la façon dont les descripteurs de fichiers sont gérés, mais doit couvrir la plupart des cas.