このページの本文へ

Windows Info 第384回

Windows 11のコンソール処理について解説する

2023年06月18日 10時00分更新

文● 塩田紳二 編集● ASCII

  • この記事をはてなブックマークに追加
  • 本文印刷

 今回はWindows Terminalの新バージョンが登場したことに合わせて、Windows 11のコンソール処理について解説する。Windows TerminalやConPTYなどの基本的な部分は過去にも記事にしてきた。今回はこれらの解説を踏まえて、新しいWindows Terminal v1.17安定版とv1.18プレビュー版の仕組みを解説したい(「Windows 11では標準コンソールの変更が可能になったのでWindows Terminalを設定する」「Windows 10までほとんど手が入れられてこなかったWindowsのコンソール機能」「Windows 10に“まとも”に使えるコンソール「Windows Terminal」が登場する」

複数存在するEXEプログラム

 非パッケージ版のWindows Terminalのインストール先フォルダを見ると、複数の実行ファイルがある。

elevate-shim.exe
OpenConsole.exe
TerminalAzBridge.exe
WindowsTerminal.exe
wt.exe

 このうち、「TerminalAzBridge.exe」は、AzureのCloud Shellに接続するときの認証用プログラムである。「elevate-shim.exe」は、管理者権限でプロファイルを起動するのに内部的に使われるものだ(エクスプローラーから実行してはいけない)。

 そして「WindowsTerminal.exe」は、Windows Terminalの本体(コンソールウィンドウを表示するプログラム)であり、「wt.exe」は標準の起動用実行ファイルだ。従来Windows Terminalは、UWPアプリケーションでwt.exeという実体のない「アプリ実行エイリアス」で起動していた。デスクトップアプリケーションになったときにも、同じ起動方法が利用できるようにwt.exeが存在している。wt.exeを起動すると、WindowsTerminal.exeが起動して置き換わる。

 「OpenConsole.exe」は、Windows Terminal用の「conhost.exe」だ。conhost.exeは、Windowsの標準ソフトウェアの1つで、コンソールAPIを処理して、コンソールウィンドウを制御する。従来のコンソールアプリケーションはコンソールAPIを使う。このとき、conhost.exeの代用としてWindows Terminalは、OpenConsole.exeを起動するわけだ。

 実は、OpenConsole.exeとWindows 11付属のconhost.exeは同じソースコードから作られている。同一のソースコードをWindows 11の標準コンポーネント用にコンパイルしたものがconhost.exeである。

 両者は同じ振る舞いをするが、OpenConsole.exeはWindows Terminalとともに配布されるため、こちらのほうが新しいバージョンになっていることがある。conhoste.exeと別にOpenConsole.exeがあるのは、conhost.exeはWindowsの標準コンポーネントであるため、アプリケーション(Windows Terminal)からは、差し替えることや起動の仕組みを変更できないからだ。エクスプローラーなどからコンソールアプリケーションを起動すると、Windowsはconhost.exeを起動し、これを変更することはできない。

 しかし、Windows Terminalに搭載される機能によっては、コンソールAPI側での対応が必要になる。このとき、Windows Terminalに同梱されているOpenConsole.exeならば、機能を簡単に追加できるが、Windowsコンポーネントの1つであるconhost.exeはWindows Updateでの配布となり、タイミングを合わせることができない。

 過去にも、Windows Terminalから起動したGUIプログラムのウィンドウをコンソールの近くに表示させるといった機能で、Windows TerminalからコンソールAPI側へ通信が必要になったが、そのための改良は先にOpenConsole.exeでなされた。このようにconhost.exeとOpenConsole.exeはほぼ同一のものだが、開発としては、OpenConsole.exeのほうが先行している。

シェルと外部コマンド

 Windowsでコマンドラインを使う場合、cmd.exeやPowerShell.exe(Windows PowerShell)、pwsh.exe(PowerShell 7.x)などのコマンドライン・インタプリタ(シェル)を起動し、その中でコマンドラインを使う。

 シェルはユーザーからの入力を受け付け、これを解釈してコマンドを実行する。このコマンドには、シェル組み込みの内部コマンドと、実行ファイルである「外部コマンド」がある。外部コマンドはファイルとしてドライブに記録されている。

 シェルを起動すると、コンソールウィンドウを開く。機械語で書かれたWin32プログラム(exeプログラム)には、プログラムがコンソール・アプリケーションであることを示すフラグがあり、これがあると自動的にコンソールウィンドウが開く。

 具体的には、Win32コンソール・アプリケーションを起動しようとすると、CSRSS(Client/Server Runtime Subsystem。実体はcsrss.exe)を使って起動される。CSRSSがconhost.exeを起動し、これがコンソールウィンドウを表示する。

 シェルは、WindowsのコンソールAPIを使って自身で管理する。このコンソールAPIを処理するのがconhost.exeだ。シェルはコンソールを開いたまま、コマンドの入力待ち状態になり、ユーザーからの入力を待ち、入力行を解釈してコマンドを実行する。

 コマンドが外部コマンドの場合、自分が作成したコンソールウィンドウを使って入出力するように準備してから外部コマンドを起動する。しかし、エクスプローラーなどにはこうした機能はなく、コンソール・アプリケーションをそのまま起動する。こうした場合、外部コマンドが終了すると同時にコンソールが閉じてしまう。

 さて、Windows 11では、従来のコマンドプロンプト・ウィンドウに加え、Windows Terminalをコンソールウィンドウとして利用できるようになっている。そのために、conhost.exeは改良されており、設定により従来のコンソールウィンドウまたは、Windows Terminalウィンドウのどちらかを開く。

 エクスプローラーからコンソールアプリケーションを起動すると、従来どおりにconhost.exeが起動する。これに対して、Windows Terminalのプロファイルを使う、あるいはwt.exeの引数としてコンソール・アプリケーションを起動すると、WindowsTerminal.exeが親プロセスとなり、OpenConsole.exeとコンソールアプリケーションを起動する。このときOpenConsole.exeは、コンソールアプリケーションが使うコンソールAPIを処理するフロントエンドとして動作する。

タブの移動が可能になったプレビュー版 v1.18

 プレビュー版のWindows Terminal v1.18では、タブのウィンドウ間の移動が可能になった。このため、v1.18では複数のウィンドウ/タブが開いても、起動するWindowsTerminal.exeは1つしかない。ウィンドウ間でタブを移動するためには、起動したシェルの環境をそのまま維持する必要があり、そのためには、接続しているOpenConsole.exeや、その親プロセスであるWindowsTerminal.exeのプロセスも維持しなければならない。

 そこでv1.18では、WindowsTerminal.exeのプロセスは1つだけに限定されている。これに対して、安定版Windows Terminal v1.17では、ウィンドウごとにプロセスが作られる。

 PowerShellでは、親プロセスの情報を以下のコマンドで取得できる。

get-process -pid (Get-CimInstance Win32_Process -filter "ProcessId=$pid").ParentProcessId

 「$pid」は、PowerShell自身のプロセスIDを格納する自動変数である。安定版Windows Terminalでは、複数のウィンドウを開くと、それぞれが別のプロセスIDを持つWindowsTerminal.exeになるが、プレビュー版Windows Terminal v1.18.1462.0では、単一のプロセスIDとなる。

 プロセスエクスプローラーで見ると、1つのWindowsTerminal.exeが親プロセスとなり、ウィンドウをいくつ開いても、すべて最初に起動されたWindowsTerminal.exeが親プロセスのままになる。

Windows Terminal プレビュー版v1.18では、1つのWindowsTerminal.exeの下ですべてのウィンドウ/タブが動作する。それに対して安定版v1.17では、ウィンドウごとにWindows Terminalのプロセスが作られる

 Windows Terminalは大きく構造を変化させた。その理由の1つは、ウィンドウ間でのタブ移動を実現するためだ。というのも、Windows Terminalのタブやペインは、稼働中のシェルプロセスに結びついている。このとき、シェルプロセスの親プロセスを勝手に変更することはできないため、すべてのウィンドウ、タブ、ペインは、同一のWindowsTerminal.exeの子プロセスにしておく必要がある。

OpenConsole.exeは直接起動できる

 OpenConsole.exeやconhost.exeを直接実行すると、従来のコンソールウィンドウ(コマンドプロンプトウィンドウ)でcmd.exeが開く(デフォルトの動作)。このことからも、両者がほとんど同じものであることがわかる。

 しかし、OpenConsole.exeでは起動オプションを使うことで、ウィンドウを開かずに実行させることが可能である。実際に稼働しているOpenConsole.exeの起動コマンドラインを得るには、

get-process | ? -Property ProcessName -like "*openconsole*" | %{ (Get-CimInstance Win32_Process -Filter "ProcessId=$($_.id)").CommandLine }

とする。

OpenConsole.exeは、conhost.exeと同等だが、Windows Terminalでは、起動オプションを指定して、挙動を変えている。起動オプション(コマンドライン)は、PowerShellのコマンドで調べることが可能だ

 Windows Terminalプレビュー版v1.18、安定版v1.17では、プログラム構造が変わり、非パッケージ版/ポータブル版でのインストールが可能になった。v1.18ではさらにウィンドウ間でのタブ移動に対応するため、Windows Terminalは単一のプロセスとして動作するようになった。タブ間の移動が可能になったことで、かなり実用的なレベルに達したといえよう。

カテゴリートップへ

この連載の記事
1
【整備済み品】 富士通 ノートパソコン LIFEBOOK MU937 超軽量 薄型ノートPC■Win11搭載 / MS Office H&B 2019 / FHD(1920x1080)/第七世代 Celeron/8GBメモリ/SSD 256GB/Webカメラ内蔵/13.3インチ
【整備済み品】 富士通 ノートパソコン LIFEBOOK MU937 超軽量 薄型ノートPC■Win11搭載 / MS Office H&B 2019 / FHD(1920x1080)/第七世代 Celeron/8GBメモリ/SSD 256GB/Webカメラ内蔵/13.3インチ
¥19,800
2
【Amazon.co.jp限定】 HP ノートパソコン 15-fd 15.6インチ インテル Core i5-1334U メモリ16GB SSD512GB Windows 11 Microsoft Office 2024搭載 カメラシャッター 指紋認証 薄型 Copilotキー搭載 ナチュラルシルバー (BJ0M4PA-AAAB)
【Amazon.co.jp限定】 HP ノートパソコン 15-fd 15.6インチ インテル Core i5-1334U メモリ16GB SSD512GB Windows 11 Microsoft Office 2024搭載 カメラシャッター 指紋認証 薄型 Copilotキー搭載 ナチュラルシルバー (BJ0M4PA-AAAB)
¥122,280
3
【整備済み品】富士通 ノートパソコン LIFEBOOK U9310 13.3型FHD(1920x1080) 超軽薄 ノートPC/第10世代 Core i5-10310U@1.7GHz/ 8GB メモリ/高速ストレージ SSD/Webカメラ/WIFI/Type-C/HDMI/win11&MS Office 2019 搭載 ビジネス 在宅勤務向け パソコン (メモリ:8GB/SSD:256GB)
【整備済み品】富士通 ノートパソコン LIFEBOOK U9310 13.3型FHD(1920x1080) 超軽薄 ノートPC/第10世代 Core i5-10310U@1.7GHz/ 8GB メモリ/高速ストレージ SSD/Webカメラ/WIFI/Type-C/HDMI/win11&MS Office 2019 搭載 ビジネス 在宅勤務向け パソコン (メモリ:8GB/SSD:256GB)
¥36,979
4
【整備済み品】中古 ノートパソコン NEC VersaPro VKT16/15.6型・第8世代Core i5-8250U(最大動作3.4GHz)/快適メモリ8GB/ 高速SSD 256GB/Win11 Pro/MS Office 2019付属/テンキー付, Webカメラ, USB3.0, HDMI, VGA, 有線LAN, WIFI内蔵, Bluetooth/ACアダプター付属/180日間保証
【整備済み品】中古 ノートパソコン NEC VersaPro VKT16/15.6型・第8世代Core i5-8250U(最大動作3.4GHz)/快適メモリ8GB/ 高速SSD 256GB/Win11 Pro/MS Office 2019付属/テンキー付, Webカメラ, USB3.0, HDMI, VGA, 有線LAN, WIFI内蔵, Bluetooth/ACアダプター付属/180日間保証
¥26,880
5
Lenovo ノートパソコン IdeaPad Slim 5 Light 13.3インチ AMD Ryzen™ 5 7535HS メモリ16GB SSD512GB バッテリー駆動22.8時間 重量1.15kg クラウドグレー 83J20009JP
Lenovo ノートパソコン IdeaPad Slim 5 Light 13.3インチ AMD Ryzen™ 5 7535HS メモリ16GB SSD512GB バッテリー駆動22.8時間 重量1.15kg クラウドグレー 83J20009JP
¥129,800

Amazonのアソシエイトとして、ASCII.jpは適格販売により収入を得ています。

ASCII倶楽部

注目ニュース

  • 角川アスキー総合研究所

プレミアム実機レビュー

ピックアップ
1
KIOXIA(キオクシア) 旧東芝メモリ microSD 128GB UHS-I Class10 (最大読出速度100MB/s) Nintendo Switch動作確認済 国内サポート正規品 メーカー保証5年 KLMEA128G
KIOXIA(キオクシア) 旧東芝メモリ microSD 128GB UHS-I Class10 (最大読出速度100MB/s) Nintendo Switch動作確認済 国内サポート正規品 メーカー保証5年 KLMEA128G
¥1,880
2
Anker PowerLine III Flow USB-C & USB-C ケーブル Anker絡まないケーブル 240W 結束バンド付き USB PD対応 シリコン素材採用 iPhone 17 / 16 / 15 / Galaxy iPad Pro MacBook Pro/Air 各種対応 (1.8m ミッドナイトブラック)
Anker PowerLine III Flow USB-C & USB-C ケーブル Anker絡まないケーブル 240W 結束バンド付き USB PD対応 シリコン素材採用 iPhone 17 / 16 / 15 / Galaxy iPad Pro MacBook Pro/Air 各種対応 (1.8m ミッドナイトブラック)
¥1,890
3
【Amazon.co.jp限定】バッファロー microSD 32GB 100MB/s UHS-1 U1 microSDHC【 Nintendo Switch 対応 】V10 A1 IPX7 Full HD RMSD-032U11HA/N
【Amazon.co.jp限定】バッファロー microSD 32GB 100MB/s UHS-1 U1 microSDHC【 Nintendo Switch 対応 】V10 A1 IPX7 Full HD RMSD-032U11HA/N
¥980
4
Anker USB Type C ケーブル PowerLine USB-C & USB-A 3.0 ケーブル iPhone 17 / 16 / 15 /Xperia/Galaxy/LG/iPad Pro/MacBook その他 Android 等 USB-C機器対応 テレワーク リモート 在宅勤務 0.9m ホワイト
Anker USB Type C ケーブル PowerLine USB-C & USB-A 3.0 ケーブル iPhone 17 / 16 / 15 /Xperia/Galaxy/LG/iPad Pro/MacBook その他 Android 等 USB-C機器対応 テレワーク リモート 在宅勤務 0.9m ホワイト
¥740
5
Anker iPhone充電ケーブル PowerLine II ライトニングケーブル MFi認証 超高耐久 iPhone 14 / 14 Pro Max / 14 Plus / 13 / 13 Pro / 12 / 11 / X/XS/XR / 8 Plus 各種対応 (0.9m ホワイト)
Anker iPhone充電ケーブル PowerLine II ライトニングケーブル MFi認証 超高耐久 iPhone 14 / 14 Pro Max / 14 Plus / 13 / 13 Pro / 12 / 11 / X/XS/XR / 8 Plus 各種対応 (0.9m ホワイト)
¥990
6
KIOXIA(キオクシア)【日本製】USBフラッシュメモリ 32GB USB2.0 国内サポート正規品 KLU202A032GL
KIOXIA(キオクシア)【日本製】USBフラッシュメモリ 32GB USB2.0 国内サポート正規品 KLU202A032GL
¥980
7
キヤノン Canon 純正 インクカートリッジ BCI-381(BK/C/M/Y)+380 5色マルチパック BCI-381+380/5MP 長さ:5.3cm 幅:13.9cm 高さ:10.75cm
キヤノン Canon 純正 インクカートリッジ BCI-381(BK/C/M/Y)+380 5色マルチパック BCI-381+380/5MP 長さ:5.3cm 幅:13.9cm 高さ:10.75cm
¥5,555
8
【Amazon.co.jp限定】 ロジクール 静音 ワイヤレス トラックボール マウス M575SPd Bluetooth Logibolt 無線 windows mac iPad OS Chrome トラックボールマウス ブラック M575 M575SP 国内正規品 ※Amazon.co.jp限定 壁紙ダウンロード付き
【Amazon.co.jp限定】 ロジクール 静音 ワイヤレス トラックボール マウス M575SPd Bluetooth Logibolt 無線 windows mac iPad OS Chrome トラックボールマウス ブラック M575 M575SP 国内正規品 ※Amazon.co.jp限定 壁紙ダウンロード付き
¥5,280
9
バッファロー SDカード 128GB 100MB/s UHS-1 スピードクラス1 VideoSpeedClass10 IPX7 Full HD データ復旧サービス対応 RSDC-128U11HA/N
バッファロー SDカード 128GB 100MB/s UHS-1 スピードクラス1 VideoSpeedClass10 IPX7 Full HD データ復旧サービス対応 RSDC-128U11HA/N
¥1,980
10
バッファロー マウス 無線 ワイヤレス 5ボタン 【戻る/進むボタン搭載】 小型 軽量 節電モデル 最大584日使用可能 BlueLED ブラック BSMBW315BK
バッファロー マウス 無線 ワイヤレス 5ボタン 【戻る/進むボタン搭載】 小型 軽量 節電モデル 最大584日使用可能 BlueLED ブラック BSMBW315BK
¥1,040

Amazonのアソシエイトとして、ASCII.jpは適格販売により収入を得ています。

デジタル用語辞典

ASCII.jpメール デジタルMac/iPodマガジン