Switch-Process
Linux および macOS では、このコマンドレットは execv()
関数を呼び出して POSIX シェルと同様の動作を提供します。
構文
Switch-Process
[[-WithCommand] <String[]>]
[<CommonParameters>]
説明
一部のネイティブ Unix コマンドは、(ssh など) 何かを実行するためにシェルアウトし、bash
組み込みコマンド exec
を使用して、現在のプロセスを置き換える新しいプロセスを生成します。 既定では、exec
は PowerShell の有効なコマンドではありません。 これは、copy-ssh-id
や AzCLI のいくつかのサブコマンドなどの一部の既知のスクリプトに影響します。
Switch-Process
コマンドレットは、POSIX シェルと同様の動作を提供するためにネイティブ execv()
関数を呼び出します。 このコマンドレットとそのエイリアス (exec
) は、PowerShell 7.3.0 で追加されました。
PowerShell 7.3.1 では、exec
エイリアスが Switch-Process
ラップされる関数に変更されました。 この関数を使用すると、WithCommand パラメーターに誤ってバインドされた可能性があるパラメーターをネイティブ コマンドに渡すことができます。
このコマンドレットは、Windows 以外のシステムでのみ使用できます。
例
例 1 - 'exec' に依存するコマンドを実行する
この例では、PowerShell が Windows 以外のシステムの既定のシェルであることを前提としています。
ssh-copy-id
は、キーベースの認証のためにターゲット マシンに公開キーをデプロイするための一般的な bash スクリプトです。 スクリプトは bash コマンドに依存 exec
。
ssh-copy-id user@host
PSExec
機能を有効にすると、ssh-copy-id
スクリプトは成功します。
パラメーター
-WithCommand
実行するネイティブ実行可能ファイル (およびすべてのパラメーター) を指定します。 引数として渡されるすべての追加値は、最初のコマンドで実行される文字列の配列として渡されます。
ターゲット コマンドは、PowerShell コマンドではなくネイティブ実行可能ファイルである必要があります。
型: | String[] |
配置: | 0 |
規定値: | None |
必須: | False |
パイプライン入力を受け取る: | False |
ワイルドカード文字を受け取る: | False |
入力
String[]
出力
メモ
Switch-Process
コマンドレットは、他の POSIX シェル exec
互換性を提供するために作成されました。 通常の条件下では、コマンドレットは PowerShell スクリプトで使用することを意図していません。
Switch-Process
には、ファイル記述子の処理方法など、POSIX シェルの組み込みの exec
関数と同等の機能はありませんが、ほとんどの場合に対応する必要があります。
PowerShell