このページの本文へ

Windows Info 第85回

Windowsの具体的なエラーコードからその意味を探る

2017年02月19日 10時00分更新

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

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

 今回は、前回紹介したマイクロソフトのエラーコードに関する文書(ERREFと呼ばれる)を使って、具体的にエラーコードからその意味を調べていくことにしよう。

 とはいえ、エラーを簡単に起こすことはできないし、エラーが起きたとしても必ずしもエラーコードを得られるとは限らない。そこで、マイクロソフトのナレッジベース文書のうち、エラーコードが記載されているものを使って、そのエラーコードが意味するものを調べてみることにする。

 サンプルに使ったのは、以下のURLにあるKB文書だ(https://support.microsoft.com/ja-jp/help/10164/fix-windows-update-errors)。

 これは、Windows Updateのエラーに関する文書。その冒頭には、Windows Updateで発生しうるエラーとして、以下の表にあるようなものが挙げられている。これらは、最上位桁が0x8なので、HRESULTまたはWin32エラー(上位4桁が0x8007の場合)だ。まずは、前回解説した方法で、エラーの分類を示す「Facility」を調べてみる。

 このFacilityが0x007の場合、つまりエラーコードの上位4桁が0x8007の場合には「Win32エラーコード」であり、そうでない場合には「HRESULTのエラーコード」となる。それぞれでテーブルを見ればエラーメッセージに翻訳できるはずだ。

 というのが前回まで解説した部分だ。まずは、マイクロソフトが公開しているエラーコードに関する文書に記載されている情報を元にエラーコードの意味を探してみた。

 Win32エラーの場合とFACILITY_NULLの場合には、ERREFの範囲で解決ができる。しかし、Facilityが「FACILITY_WINDOWSUPDATE」(0x024)の場合のコードがほとんど記載されておらず、エラーの内容を知ることができなかった。 ERREFは、昨年改訂された文書なのでそれほど古いものではなく、Windows Updateも当然範疇に含まれるはずだが、実際に表を調べて見ると、ほとんど記載がなかった。

 そこで、マイクロソフトのサイトを捜したところ以下のURLにWindows Updateのエラーコードがあることがわかった。

●Windows Update error code list
 https://support.microsoft.com/ja-jp/help/938205/windows-update-error-code-list

 しかし、これは2011年のもので、その後の更新もなく、それほど新しいものではない。ここには複数のリストがあるが、明確にエラーコードになっているのは3つ目のリスト以降のものだ。

 最初のものは、Component Based Servicing (CBS) interface methodsが戻すエラーコードだというが、下位20bit分(16進5桁)しか表記されてない。おそらく、FACILITY_SETUPAPI(0x800F)に対応するものだと思われる。つまり、ここにある「0xF0xxxx」は、エラーコードとして表示される場合(HRESULTとして受け渡される場合)には、0x800F0xxxというエラーになるはずだ。

 ちなみにCBSは、Vista、Windows Server 2008世代で導入された技術で、Winods UpdateやWindows Installerで内部的に使われている。このCBSを利用するAPI自体は公開されていない。すでに解説ページなどはMSDN上にはないが、以下の記述がTechNetに残っている(https://technet.microsoft.com/ja-jp/library/cc756291%28v=ws.10%29.aspx?f=255&MSPPError=-2147217396)。

 おそらく、内部的に使われているCBS関連APIからのエラーコードがそのままWindows Updateのエラー値として使われることがあるということなのだと思われる。なので、エラーコードそのものではなく、エラーコードと共に提示される拡張コードとして示される可能性もある。

 2つめのリストは、エラーが起こっていない場合のHRESULT値であり、「成功コード」(Success code)と呼ばれるもの。メッセージを見るとERRORという文字もある。たとえば、すでに適用したアップデートをもう一度適用しようとした場合、当然そのことが報告される。このときの値が「WU_S_ALREADY_INSTALLED」だ。適用しようとしたアップデートが適用できなかったというエラーではあるが、アップデートが失敗したわけではない(すでに成功終了している)、という意味でエラーを表すビットが1になっていない。つまりエラーコードとしては0x8から始まらない。ただし、構造的には、HRESULT形式に準拠している。

 3つめ以降のリストが、エラー時に表示される「エラーコード」である。とりあえず、ここにあるコードで、サンプルとして取り上げたナレッジベース文書に記載されているFACILITY_WINDOWSUPDATEのエラー内容は確定できる。

 ただ、エラーコードが示しているエラーの中には、あまり役に立たないように見えるものもある。たとえば、0x80004005は「Unspecified error」(特定できないエラー)となっていて、何が原因で何が起こったのかさえわからない。

 こうなる原因はさまざまだが、利用しているソフトウェアモジュールがエラーコードを正しく戻さない場合などが考えられる。たとえば、エラーにより、ソフトウェアがクラッシュしてしまい、何も情報が戻らなかった場合などだ。このような場合には、ログファイルなど、エラーコード以外の情報から原因を特定するしかない。

 逆に「0x80073712」は「ERROR_SXS_COMPONENT_STORE_CORRUPT」で、説明が「The component store has been corrupted」となっていて、Windows コンポーネントストアがおかしな状態になっていることを示す。「SxS」(Side by Sideを意味する)や「Componet Store」といったキーワードからいろいろと調べることができる。

 コンポーネントストアは、アプリケーションから共有できる機能をまとめたコンポーネントの複数バージョン(アプリケーションによって対応できるコンポーネントのバージョンが異なる場合がある)を保持するためのWindowsの仕組みだ。かつては、アプリケーションと特定バージョンのコンポーネントの関係を無視して、コンポーネントを自由に更新させたため、「DLL地獄」という問題を引き起こしていた。コンポーネントストアには、多くのコンポーネントがインストールされるため構造が複雑で、不完全な操作により、構造的な矛盾が生じてしまうことがある。なお、このエラーを解決するにはDISMコマンドが利用できる。

 一般に、エラーコードを定義して複数のソフトウェアで使う場合、同じコードに複数の意味を持たせることは不可能になる。というのは、一回、ユーザーの手に渡ったプログラムは、いつまで使われるかが不明であるため、同一のコードの意味を変えてしまうと、エラーコードの報告を受けてサポートを行う場合に、間違ったエラーとして認識される可能性があるからだ。

 このことには良い面と悪い面がある。良い面とは、エラーコードの意味が変わらないため、エラーコードやエラーメッセージでの検索は有効だということとであり、悪い面は、過去のバージョンのソフトウェアでも同じエラーコードが使われているため、検索すると古いプラットフォームの情報も見つかってしまうことだ。この問題があるため、エラーコードやエラーメッセージを使った検索では、対象となるプラットフォーム名(Windows 10など)を検索キーワードに含めようにする。

 とりあえず、エラーコードを、エラーメッセージに直すところまではなんとかこぎ着けたが、数値の並びを見るに、まだ公開されていないエラー情報のリストがあると思われる。とりあえず、数字の羅列というところからは脱したという感じでしかないが、次回はエラーメッセージなどを手がかりにもう少しエラーについて見ていくことにしよう。

カテゴリートップへ

この連載の記事

ASCII倶楽部

注目ニュース

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

プレミアム実機レビュー

ピックアップ
1
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
2
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
3
CIO フラットスパイラルケーブル CtoC 1m (Type-C/USB-C) PD 急速充電 平型 磁石 マグネット吸着 まとまる 充電ケーブル PD 240W データ転送 480Mbps (ライトブラック, 1m)
CIO フラットスパイラルケーブル CtoC 1m (Type-C/USB-C) PD 急速充電 平型 磁石 マグネット吸着 まとまる 充電ケーブル PD 240W データ転送 480Mbps (ライトブラック, 1m)
¥1,980
4
エレコム 電源タップ 6個口 3m 雷ガード 個別スイッチ ほこりシャッター付 耐熱 PSE技術基準適合 ブラック T-K6A-2630BK
エレコム 電源タップ 6個口 3m 雷ガード 個別スイッチ ほこりシャッター付 耐熱 PSE技術基準適合 ブラック T-K6A-2630BK
¥2,111
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
【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限定 壁紙ダウンロード付き
¥7,035
7
Verbatim バーベイタム 1回録画用 ブルーレイディスク BD-R 25GB 50枚+3枚増量パック インクジェットプリンタ対応 ホワイト 片面1層 1-6倍速
Verbatim バーベイタム 1回録画用 ブルーレイディスク BD-R 25GB 50枚+3枚増量パック インクジェットプリンタ対応 ホワイト 片面1層 1-6倍速
¥2,480
8
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, ブラック)
¥1,299
9
Amazon Kindle - 目に優しい、かさばらない、大きな画面で読みやすい、6週間持続バッテリー、6インチディスプレイ電子書籍リーダー、ブラック、16GB、広告なし
Amazon Kindle - 目に優しい、かさばらない、大きな画面で読みやすい、6週間持続バッテリー、6インチディスプレイ電子書籍リーダー、ブラック、16GB、広告なし
¥19,980
10
KIOXIA(キオクシア)【日本製】USBフラッシュメモリ 32GB USB2.0 国内サポート正規品 KLU202A032GL
KIOXIA(キオクシア)【日本製】USBフラッシュメモリ 32GB USB2.0 国内サポート正規品 KLU202A032GL
¥1,100

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

デジタル用語辞典

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