このページの本文へ

Windows Info 第82回

Windows Subsystem for LinuxからWindowsバイナリが起動可能に

2017年01月29日 10時00分更新

文● 塩田紳二 編集● ASCII.jp

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

 現在配布が行なわれているWindows Insider Program(WIP)のRS2 Insider Preview Build 14951以降(以下プレビュー版と略す)では、Windows Subsystem for Linux(WSL、Bash on Windows:BOWとも)の機能が拡張されており、bash側からWindowsデスクトップアプリケーション(Win32アプリケーション)の起動が可能になった。

 マイクロソフトのブログでは、この機能を「Windows Subsystem for Linux - interoperability with Win32 applications」と呼んでいる(以下、Win32相互運用性と略す)。

 このWin32相互運用性は、単純にWin32アプリケーションを起動するだけでなく、引数に指定された「ファイルパスの変換」と「標準入出力などリダイレクションの制御」も行なう。

 また、WSLを起動するinitプロセスの機能が拡張されており、起動時のWindows側のPATH環境変数をWSL側に持ち込むようだ。このため、特にWin32側のPATH設定などをしなくても、Win32アプリケーションを起動できるようになる。ただし、Linuxでは実行ファイルの拡張子の省略(Windowsではexe/com/batの拡張子は省略可能)がないため、実行ファイルは「cmd.exe」のようにファイル名を完全に指定する必要がある。

WindowsとLinux間のパスの変換

 Win32相互運用性では、Win32アプリ側が動作するのはWindows環境だが、起動するbashはWSL内となる。Windowsの環境では、パスにドライブ名などを含むパス表記(UNC、Universal Naming Convention)が使われる。これに対してWSL内では、Linuxのパス表記方法が使われている。

 WSLには2つのファイルシステムがあり、1つはLinuxのファイルシステム(ルートディレクトリ以下)であり、これはVolFS(Volume File System)と呼ばれている。もう1つは、WSL側からWindows側のファイルをアクセスするためのDrvFS(Drive File System)で、こちらは、VolFSの/mnt/以下にドライブ文字のディレクトリが作られ、たとえば「/mnt/c」が「C:\」に相当する。

 コマンドラインの引数は、プログラム自身が解釈し、必要に応じてファイル名をフルパスなどに変換している。このとき、使われる「カレントディレクトリ」(Windowsではカレントフォルダ)は、プログラムの起動時に環境情報として渡される。プログラムを起動するbash側では、引数のどれがファイルなのかは判断できず、単純に引数にある環境変数やシェル変数などを展開(変数を変数値で置き換える)するだけだ。

 このため、Win32相互運用性でも、引数自体にはまったく手をつけないが、環境情報である「カレントディレクトリ」だけは、パスをUNCに変換して、Windows側に手渡す。

 ただし、VolFS(WSLのルートディレクトリ以下、DrvFS以外の部分)内のパスがカレントディレクトリだった場合には、現在のWin32相互運用性では、Bash.exeの起動フォルダである「%windir%\system32」(一般的にはC:\Windows\System32)が使われる。

 VolFSは、Linux側のファイルシステムであるため、Windows側からのアクセスが制限されている。これは、WindowsとLinuxではファイルロックのポリシーが違い、安全なアクセスを実現するためのコストが小さくないからだ。このため、VolFS側にあるファイルは、Win32相互運用性ではアクセスすることができない。処理する場合には、Linux側でVolFSからDrvFS側にファイルをコピーするなどが必要になる。

 WSL側では引数を勝手には変換しないため、Win32プログラムの引数に直接Windowsのパスを記述することもできる。

WSL側でWin32アプリケーションを起動するとき、\はbashが解釈するエスケープ文字なので\\とするか、パスをシングルクオートで括る

 注意したいのは、UNCで使われる\(逆スラッシュ)は、bashのコマンドラインではエスケープ文字として解釈されるため、表記に注意が必要になることだ。具体的には「\」を「\\」としてエスケープ文字として解釈が行われてもいいようにするか、Windows側のパスをシングルクオートで括り、エスケープ文字の解釈を行わせないようにするかである。

notepad.exe 'c:\temp\test.txt' 引数をシングルクオートで囲む
notepad.exe c:\\temp\\test.txt \を\\とする

 実は、Windows自体は、パスの区切り文字としてスラッシュ「/」も受け付けるため、必ずしも、逆スラッシュ(円マーク)で指定しなくてもよい。たとえば、前述の例では、

notepad.exe c:/temp/test.txt

と表記しても動作する。ただし、Windowsのコマンドラインプログラム(GUIを持たずコンソールで動作することを前提に作られたコマンドライン用実行プログラム)では、この表記がエラーになる。

 標準のオプション指定文字がスラッシュであるため、これをファイルパスとは解釈しないからだ。たとえば、「dir」コマンドは、ファイルパスは逆スラッシュ区切りでしか受け付けない。逆にGUIを使うWin32プログラムの大半はオプション指定を持たないため、スラッシュ区切りでもパスを解釈できるものが多い。ただし、GUIを使うプログラムの中にもオプション指定を受け付けるものがある。

 逆に、引数としてDrvFSのパスを直接表記してしまうとエラーになる。

notepad.exe /mnt/c/Temp/test.txt エラー
cd /mnt/c/Temp カレントディレクトリを使う
notepad.exe test.txt エラーにならない

 エラーになるのは、引数などは変換されずにそのままWin32アプリケーションに渡されるからだ。Win32アプリケーションは、UNC形式のパスが前提であるため、DrvFS形式のパスを解釈できない。

標準入出力の変換

 Win32相互運用性のもう1つの機能が、WSLとWindows側の標準入出力の接続だ。Windowsでもbashでも、パイプ"|"でプログラム間の標準入出力を接続したり、">"や"<"で切り替えを行なうことができるが、Win32相互運用性では、WSLとWindowsの標準入出力を接続することができる。たとえば、bash上で

cmd.exe /c dir | grep "test"

として、WSLでWin32ソフトウェアであるcmd.exeを起動し、その出力をWSL側のLinuxソフトウェアであるgrepの標準入力と接続できる。

Win32相互運用性では、Win32とWSL間で標準入出力によるデータの受け渡しが可能

逆に

ls | find.exe '"test"'

として、Linuxのlsコマンドの出力をWin32側のFind.exeの入力と接続することも可能。ただし、Find.exeの引数はダブルクオートで括る必要があるが、Bashが解釈して評価した結果としてダブルクオートをはずしてしまうためシングルクオートでくくり、ダブルクオートが解釈されないようにする必要がある。

 リダイレクションは、bashが解釈して、WSL側で標準入出力を設定するため、リダイレクト先のファイルの指定には、WSL側のパス指定を使う必要がある。Win32アプリケーションでも、VolFS内へのファイルの書き込みが利用できる。

リダイレクションを使えばWin32アプリからLinux側のファイルシステム(VolFS)へのアクセスが可能になる

 だが、Windows側では、コマンドプロンプトウィンドウ内で

dir | bash -c "grep 'test'"

として、cmd.exe側の標準入出力をbash側へつなぐことはできないようだ。bash.exe自体には、標準入出力はあるものの、それをWSL側で起動される/bin/bashに接続することはできない。Win32相互運用性があるため、前述のようにWSLからcmd.exeを起動するなどしてWindows側でコマンドを動作させれば実質的には同等のことが可能となるため、基本的には問題になることはないだろう。

 次回は、このWin32相互運用性を実現している仕組みについて解説する。

カテゴリートップへ

本記事はアフィリエイトプログラムによる収益を得ている場合があります

この連載の記事
1
Apple 2026 MacBook Neo A18 Proチップ搭載13インチノートブック:AIとApple Intelligenceのために設計、Liquid Retinaディスプレイ、8GBユニファイドメモリ、512GB SSDストレージ、1080p FaceTime HDカメラ、Touch ID - インディゴ
Apple 2026 MacBook Neo A18 Proチップ搭載13インチノートブック:AIとApple Intelligenceのために設計、Liquid Retinaディスプレイ、8GBユニファイドメモリ、512GB SSDストレージ、1080p FaceTime HDカメラ、Touch ID - インディゴ
¥110,162
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
【整備済み品】富士通 ノートパソコン 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
4
【Amazon.co.jp限定】Lenovo Chromebook クロームブック Duet 11 10.95インチ MediaTek Kompanio 838 プロセッサー​搭載 メモリ8GB eMMC 128GB 重量1.0kg 83HH000TJP パソコン
【Amazon.co.jp限定】Lenovo Chromebook クロームブック Duet 11 10.95インチ MediaTek Kompanio 838 プロセッサー​搭載 メモリ8GB eMMC 128GB 重量1.0kg 83HH000TJP パソコン
¥49,800
5
ESBOOKノートパソコン 【MS Office 2024搭載&Windows 11 Pro】14インチIPS液晶/1920×1080FHDディスプレイ カメラ付き/薄型PCノート高性能CPU/初期設定不要/8Gメモリ/無線LAN/大容量SSD/初心者向け・パソコンノート/日本語キーボードフィルム付き/ワイヤレスマウス付き(256G SSD, ローズゴールド)
ESBOOKノートパソコン 【MS Office 2024搭載&Windows 11 Pro】14インチIPS液晶/1920×1080FHDディスプレイ カメラ付き/薄型PCノート高性能CPU/初期設定不要/8Gメモリ/無線LAN/大容量SSD/初心者向け・パソコンノート/日本語キーボードフィルム付き/ワイヤレスマウス付き(256G SSD, ローズゴールド)
¥38,999

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
¥2,280
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,390
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
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
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
¥937
7
NIMASO ガラスフィルム iPad 第11世代(A16) 2025用/iPad 10.9インチ 第10世代 2022用 衝撃吸収 強化 ガラス 保護フィルム 指紋防止 ガイド枠付き NTB22I574
NIMASO ガラスフィルム iPad 第11世代(A16) 2025用/iPad 10.9インチ 第10世代 2022用 衝撃吸収 強化 ガラス 保護フィルム 指紋防止 ガイド枠付き NTB22I574
¥1,359
8
KIOXIA(キオクシア)【日本製】SDカード 64GB SDXC UHS-I Class10 読出速度100MB/s 国内正規品 メーカー保証5年 KLNEA064G
KIOXIA(キオクシア)【日本製】SDカード 64GB SDXC UHS-I Class10 読出速度100MB/s 国内正規品 メーカー保証5年 KLNEA064G
¥1,580
9
エルパ(ELPA) 扉付タップラン 電源タップ 延長コード 125V 3m 3個口 ホワイト WBT-N3030B(W)
エルパ(ELPA) 扉付タップラン 電源タップ 延長コード 125V 3m 3個口 ホワイト WBT-N3030B(W)
¥652
10
バッファロー マウス 無線 ワイヤレス 5ボタン 【戻る/進むボタン搭載】 小型 軽量 節電モデル 最大584日使用可能 BlueLED ブラック BSMBW315BK
バッファロー マウス 無線 ワイヤレス 5ボタン 【戻る/進むボタン搭載】 小型 軽量 節電モデル 最大584日使用可能 BlueLED ブラック BSMBW315BK
¥1,040

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

デジタル用語辞典

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