MySQL/C++ Connector パッケージを使用して、ローカルでホストされている自分の MySQL データベースに接続しようとしています。本当に問題を引き起こしている行は次のとおりです。
driver = get_driver_instance();
auto_ptr < Connection > con (driver -> connect("tcp://127.0.0.1:3306", "root", "root"));
2 行の 2 行目にヒットすると、メモリ割り当てエラーが発生します。デバッガーからの読み出しは次のとおりです。
HEAP[mySQLTestApp.exe]: Invalid allocation size - CCCCCCD0 (exceeded 7ffdefff)
First-chance exception at 0x7c812afb in mySQLTestApp.exe: Microsoft C++ exception: std::bad_alloc at memory location 0x0012fa88..
HEAP[mySQLTestApp.exe]: Invalid allocation size - CCCCCCCD (exceeded 7ffdefff)
First-chance exception at 0x7c812afb in mySQLTestApp.exe: Microsoft C++ exception: std::bad_alloc at memory location 0x0012f428..
First-chance exception at 0x7c812afb in mySQLTestApp.exe: Microsoft C++ exception: [rethrow] at memory location 0x00000000..
Unhandled exception at 0x7c812afb in mySQLTestApp.exe: Microsoft C++ exception: std::bad_alloc at memory location 0x0012f428..
何が間違っているのか本当にわかりません。接続ポインタそのものではないかと思ったので、今ご覧のauto_ptrに変換してみました。同じエラー。connect 関数にさまざまなパラメーターを試してみましたが、それも問題ではないようです。プログラムの早い段階でメモリリークの問題が発生する理由を誰か説明できますか?