このページの本文へ

Windows Info 第135回

Windows 10までほとんど手が入れられてこなかったWindowsのコンソール機能

2018年07月29日 10時00分更新

文● 塩田紳二 編集● ASCII編集部

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

64bit版Windowsでは16bitのDOSアプリは動かなくなったが
32bitのコンソールアプリは動作可能

 「コマンドプロンプト」や「WSL」(Windows Susbsytem for Linux)を使う場合に利用するのが「コンソール」ウィンドウだ。このコンソールウィンドウは、テキスト主体のアプリケーションを実行する環境である。

 Windowsでは、その祖先にあたるMS-DOSのアプリケーションをサポートするためにコンソールウィンドウが作られ、Windows XPまでは、16bitアプリケーションとしてMS-DOSアプリを動作できた。64bit版のVistaからは16bitアプリケーションのサポートはなくなったが、32bitのコンソールアプリケーションは実行できる。

 もともとコンソールとは、ハードウェアとして、テキストの表示とキーボードからの入力をサポートしたもので、OSの支援などがなくても入出力を可能にするものとしてコンピューターに組み込まれていた。

 現在では、こうしたコンソールは逆に「ハードウェアコンソール」として区別するのが普通になったように、Windowsなどの「コンソールウィンドウ」はOSが実行環境を作り、他のアプリケーションと共存できるようにウィンドウ内で入出力を行うための仕組みになっている。なお、Windows 10 RS4(Spring Update)からは、UWPアプリでもコンソールアプリケーションを開発することが可能になった。

 コンソールウィンドウとアプリケーションは、単一のソフトウェアのように見えるが、実際には、アプリケーションとConhost.exeという2つのプログラムに分かれていて、Win32APIを介してConDrvというカーネル内のデバイスドライバーで接続されて動作している。コンソールアプリケーションとConHost.exeの間にConDrvを挟むのは、1つのコンソールアプリケーションから複数の子プロセスが起動され、同じコンソールを利用することになる場合があるからだ。

 たとえば、コマンドプロンプトウィンドウ(cmd.exe)は、起動するとコンソールウィンドウを表示するが、その中でさらにcmd.exeを起動することができる。このとき、最初に起動したコンソールを2つのcmd.exeが共有している状態となる。なお、Windowsでは、コンソールアプリケーション(プロセス)が接続できるコンソールウィンドウは1つだけに制限されている。

 ConHost.exeが導入されたのはWindows 7からで、これ以前では、コンソール表示は「Client Server Runtime SubSystem(CSRSS)」というサブシステムで行なっていた。もともと、これは、Windows NTで仮想DOSマシンのサポートやコンソールウィンドウの管理などのために作られたもの。

 GUIで起動するWindows NTは、当初はGUIなしのOSとして動作していたこともあり、システムとしてGUIを使わないコマンドなどが多数用意されていたのだ。また、従来のMS-DOSとの互換性も必要であり、これはMS-DOSの上で動いていた、当時のWindowsとの互換性からも必要なことだった。

 コマンドライン用アプリケーションは、バックグラウンド処理として画面入出力を止めた状態で動作し続けることが要求される可能性があった。実際、マイクロソフトが手本としたUnix系では、コマンドをバックグラウンドで起動したり、デーモンとして動作させるという技法が使われている。Windows NTでもこうした挙動を可能にするため、CSRSSがWindowsの機能で導入された。

セキュリティ問題への対応でWindows 7で若干の手が加わる

 Windows Vista以前、コンソールはCSRSS.EXEというシステムコンポーネントが使われていた。しかし、ユーザーモードで動作するソフトウェアでありながら、GDIやウィンドウの制御にカーネルモードドライバーを直接呼び出すなど、セキュリティ的な問題があった。

 このため、Windows 7では、CSRSS.EXEから、コンソール関連の機能を分離し、conhost.exeとした。

アプリケーションがコンソールを使う場合、ConHost.exeが子プロセスとして起動され、これがコンソールウィンドウの制御をする

 コンソール機能は、アプリケーションの子プロセスとして実行されるようになった。このようにすることで、conhost.exe側に問題が生じたとしても、アプリケーション環境の中の問題として処理することが可能になる。

 Unix系などのコンソールアプリケーションとの違いとして、本来Windowsのコンソールアプリケーションは、コンソールAPIを介して、コンソールウィンドウ内の表示を細かく制御することを想定している。これに対して、Unix系のコマンドでは、コマンドは、「標準入力」「標準出力」「標準エラー出力」といった仮想的な入出力デバイスを前提に作られている(そもそも開発された時代が違う)。

 Unixコマンドプログラムは、これらの入出力デバイスを使って、入力を受け取り、結果出力を行なう。さらに言えば、Unix系では、これらを「ファイルの読み書き」のように扱うようになっている。入力デバイスをファイルのように読み出せば、ユーザーがタイプした文字などが入力データとして得られ、結果などをテキストとして、出力デバイスに書き込めば、勝手に画面に表示される。

 MS-DOS時代には、Unixを手本としていたため、同じような標準入出力が用意された。WindowsのコンソールAPIにも、同様のことを実現する高レベルAPIが用意された。しかし、コンソール上で動作するアプリケーションのサポートが完成の域にあったUnixとは違い、MS-DOSでのサポートは、初期の16bit CPU向けの簡易な機能のみで、その後、マイクロソフトはWindowsとGUIプログラムへと移行したため、コンソールプログラムのサポートは中途半端なまま残されることになる。

 実際、Windowsのコンソール機能は、Windows 10にWSLが導入されるまで、ほとんど手がつけられていない。前述のConHost.exeの分離なども、CSRSS.EXEが攻撃対象となったからであり、あくまでセキュリティ対策だったのであり、当時は、コンソール機能を強化するという意図はなかったようだ。

 また、WSLとともに復活したDEC VT100のエスケープシーケンスのサポートも、MS-DOSや初期の16bit版Windowsでは、デバイスドライバーとして実現されていたのだが、WindowsとMS-DOSが分離されたために廃止された機能だった。

30年以上の前のコードがベース
Unicode対応に問題が生じている

 ConHost.exeは、コンソールアプリケーションに対して、子プロセスとして起動され、ウィンドウの管理や表示、入力などをする。このコードは、古いものを改良して使い続けられていると考えられる。というのは、いまだにフォントとして古いラスターフォント(TrueType導入以前のWindowsフォント形式)を扱えるなど、GDI経由で出力されているからだ。マイクロソフトのブログによれば、30年以上前のコードがベースになっているという。

 ただし、まったく手が入っていないわけではなく、たとえば、WSL導入時に組み込まれたVT100エスケープシーケンスなどは、このConHost.exe内で処理されている。MS-DOSやWindowsが複数の文字コードセットに対応していたことから、コンソールは文字コードセットの切り替え機能を持つ。

 また、日本語など2バイトコード文字への対応は、現在では拡張されてUnicodeによるものとなった。ただし、前述のようにコンソールはGDIベースであるため、Unicodeの処理については完全ではなく、複数の文字を組みあわせて1つにするような表示ができない。今後、改良されるとすれば、こうした表示関係の機能を最新のものに合わせていくことになるかと思われるが、逆に過去に作られたコンソールAPIを利用するデスクトップアプリケーションとの互換性などが足かせとなる。

 しかし、Unicodeの完全な表示は、たとえばLinuxのコンソールアプリケーションなどでも問題になることがあり、対応が急がれるところ。互換性をとるのか、捨てるのか、対応が非常に気になる部分でもある。個人的にはそろそろGDIは捨ててDirectWriteベースに移行してくれると、文字表示がきれいになるので期待したいところだ。

カテゴリートップへ

この連載の記事
1
Apple 2026 MacBook Neo A18 Proチップ搭載13インチノートブック:AIとApple Intelligenceのために設計、Liquid Retinaディスプレイ、8GBユニファイドメモリ、256GB SSDストレージ、1080p FaceTime HDカメラ - シルバー
Apple 2026 MacBook Neo A18 Proチップ搭載13インチノートブック:AIとApple Intelligenceのために設計、Liquid Retinaディスプレイ、8GBユニファイドメモリ、256GB SSDストレージ、1080p FaceTime HDカメラ - シルバー
¥95,768
2
Apple 2026 MacBook Air M5チップ搭載13インチノートブック:AIとApple Intelligence、13.6インチLiquid Retinaディスプレイ、16GBユニファイドメモリ、512GB SSDストレージ、12MPセンターフレームカメラ、Touch ID - シルバー
Apple 2026 MacBook Air M5チップ搭載13インチノートブック:AIとApple Intelligence、13.6インチLiquid Retinaディスプレイ、16GBユニファイドメモリ、512GB SSDストレージ、12MPセンターフレームカメラ、Touch ID - シルバー
¥177,333
3
Lenovo Chromebook クロームブック IdeaPad Flex 3i Gen8 12.2インチ インテル® プロセッサー N100搭載 メモリ4GB eMMC 64GB バッテリー駆動12.0時間 重量1.25kg アビスブルー 82XH001KJP
Lenovo Chromebook クロームブック IdeaPad Flex 3i Gen8 12.2インチ インテル® プロセッサー N100搭載 メモリ4GB eMMC 64GB バッテリー駆動12.0時間 重量1.25kg アビスブルー 82XH001KJP
¥38,500
4
Lenovo ノートパソコン パソコン IdeaPad Slim 3 15.3インチ 第13世代 インテル® Core™ i5 プロセッサー搭載 13420H メモリ16GB SSD512GB MS Office 2024搭載 Windows11 バッテリー駆動16.9時間 重量1.59kg ルナグレー 83K100G4JP ノートPC
Lenovo ノートパソコン パソコン IdeaPad Slim 3 15.3インチ 第13世代 インテル® Core™ i5 プロセッサー搭載 13420H メモリ16GB SSD512GB MS Office 2024搭載 Windows11 バッテリー駆動16.9時間 重量1.59kg ルナグレー 83K100G4JP ノートPC
¥107,800
5
【整備済み品】富士通 ノートパソコン 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,970

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,980
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
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
4
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
5
UGREEN USB Type Cケーブル PD対応 100W/5A 超急速充電 USB C ナイロン編み 断線防止 iphone17/16/15シリーズ/iPad/MacBook Pro/Galaxy S24/Matebook/iPad/Xperia等USB-C各種対応(1m, ブラック)
UGREEN USB Type Cケーブル PD対応 100W/5A 超急速充電 USB C ナイロン編み 断線防止 iphone17/16/15シリーズ/iPad/MacBook Pro/Galaxy S24/Matebook/iPad/Xperia等USB-C各種対応(1m, ブラック)
¥743
6
KIOXIA(キオクシア)【日本製】USBフラッシュメモリ 32GB USB2.0 国内サポート正規品 KLU202A032GL
KIOXIA(キオクシア)【日本製】USBフラッシュメモリ 32GB USB2.0 国内サポート正規品 KLU202A032GL
¥1,100
7
エレコム 電源タップ 6個口 3m 雷ガード 個別スイッチ ほこりシャッター付 耐熱 PSE技術基準適合 ホワイト T-K6A-2630WH
エレコム 電源タップ 6個口 3m 雷ガード 個別スイッチ ほこりシャッター付 耐熱 PSE技術基準適合 ホワイト T-K6A-2630WH
¥1,899
8
キヤノン 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
¥4,918
9
エルパ(ELPA) 扉付タップラン 電源タップ 延長コード 125V 3m 3個口 ホワイト WBT-N3030B(W)
エルパ(ELPA) 扉付タップラン 電源タップ 延長コード 125V 3m 3個口 ホワイト WBT-N3030B(W)
¥652
10
KIOXIA(キオクシア)【日本製】SDカード 64GB SDXC UHS-I Class10 読出速度100MB/s 国内正規品 メーカー保証5年 KLNEA064G
KIOXIA(キオクシア)【日本製】SDカード 64GB SDXC UHS-I Class10 読出速度100MB/s 国内正規品 メーカー保証5年 KLNEA064G
¥1,180

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

デジタル用語辞典

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