x64 でビルドしたアプリを実行したとき、0xC000007B で起動できないことがあります。
アプリケーションを正しく起動できませんでした (0xc000007b)。
[OK] をクリックしてアプリケーションを閉じてください。
このエラーは、アプリ本体と読み込まれる DLL の 32bit / 64bit が一致していない ときに発生します。
この記事では、最初に確認する場所と、依存 DLL を特定して修正する順番を整理します。
原因整理:0xC000007B の意味

このエラーの根本原因は非常にシンプルです。
「アプリケーション本体(EXE)のビット数と、それが読み込もうとしたDLLのビット数が一致していない」 ことです。
例えば、以下のようなケースで発生します。
- パターンA: 本体EXEを x64(64bit)でビルドしたのに、古い外部ライブラリ(
xxx.dll)が x86(32bit)のまま配置されている。 - パターンB: その逆。本体は x86(32bit)なのに、システムのSystem32フォルダにある64bit版DLLを誤って参照してしまった。
Windowsは、64bitプロセス空間に32bitのDLLをロードすることを絶対に許しません(その逆も同様です)。ロードしようとした瞬間にOSレベルで弾かれ、0xC000007b(STATUS_INVALID_IMAGE_FORMAT)という例外を投げます。
解決手順:依存関係の調査と修正フロー
最初に行うのは、どの DLL のビット数が合っていないかを特定することです。
Step 1: dumpbin ツールで本体のビット数を確認する
まずは、ビルドした EXE が意図したビット数になっているか確認します。Visual Studio の「Developer Command Prompt」を開き、以下のコマンドを実行します。
dumpbin /headers YourApp.exe | findstr machine
Before (間違った設定でビルドされた例)
14C machine (x86)
After (正しい64bitビルドの例)
8664 machine (x64)
もし本体が x86 になっているのに開発環境では x64 を選んだつもりなら、構成マネージャーの設定が「Active(x64)」であっても特定のプロジェクトだけWin32向けにビルドされている可能性があります。構成マネージャーを再確認してください。
Step 2: 依存関係を調査するツールを使う
本体が正しいなら、次に確認するのは一緒にロードされる DLL です。Dependency Walker (depends.exe) や Dependencies で EXE を開きます。

- EXEをツールにドラッグ&ドロップします。
- 左側のツリーや一覧の中で、CPUの列が
x86(EXEがx64の場合)になっている赤字のDLLを探します。 - 特に、社内ライブラリやサードパーティコンポーネント(連携用の
HogeLib.dllなど)をそのまま同じフォルダにコピーしていないか確認します。
Step 3: 正しいビット数のDLLに置き換える
原因のDLLが特定できたら、対応は簡単です。
- サードパーティ製ライブラリであれば、提供元から
x64版(またはx86版)をダウンロードして同梱し直す。 - 自社製の別プロジェクトDLLなら、そのDLLプロジェクト自体を
x64構成でビルドし直す。
開発者向けTips:LoadLibrary でも同じ不一致が起きる
このエラーは起動時だけでなく、アプリ動作中の動的ロード(LoadLibrary)でも発生します。暗黙的リンク(インポートライブラリへのリンク)の場合は起動時エラーになりますが、明示的リンクの場合は以下のようになります。
#include <windows.h>
#include <iostream>
int main()
{
// 64bitアプリから32bitのDLLを動的にロードしようとした場合のシミュレーション
HMODULE hMod = ::LoadLibraryExA("LegacyPlugin32.dll", NULL, DONT_RESOLVE_DLL_REFERENCES);
if (hMod == NULL) {
DWORD err = ::GetLastError();
if(err == ERROR_BAD_EXE_FORMAT) { // 193
std::cerr << "エラー: 193 (ERROR_BAD_EXE_FORMAT) - ビットネスが不一致です。" << std::endl;
} else {
std::cerr << "別のエラー: " << err << std::endl;
}
}
return 0;
}
ログに「193」というエラーコードが残っていたら、それは APIの失敗ではなく、ビットネス混在によるロード拒否(実質的な 0xC000007B) を意味します。
まとめ(再発防止チェックリスト)
- [ ]
0xC000007Bエラーが出たら、コードではなく32bit/64bitの混在を疑う - [ ] 構成マネージャーで、本体と依存プロジェクトのプラットフォーム(x64 / Win32)がすべて一致しているか確認する
- [ ] 実行フォルダにコピーしている外部DLL(OpenCV, 独自ドライバ等)のビット数が間違っていないか確認する
- [ ] 迷ったら
Dependenciesなどのツールでファイルを開き、赤くマークされたアーキテクチャ不一致のDLLを特定する
開発環境の移行期(特に VS のバージョンアップに合わせて 32bit から 64bit へ移行する際)に起きやすいエラーです。依存関係を一つずつ確認してください。
