2

我一直在尝试使用 MySQL/C++ 连接器包连接到我自己的本地托管 MySQL 数据库。真正给我带来问题的行是:

driver = get_driver_instance();
auto_ptr < Connection > con (driver -> connect("tcp://127.0.0.1:3306", "root", "root"));

击中两行中的第二行会给我一个内存分配错误。这是调试器的读数。

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..

我真的不确定我做错了什么。我认为它可能是 Connection 指针本身,所以我尝试将其转换为您现在看到的 auto_ptr。同样的错误。我已经为连接函数尝试了不同的参数,但这似乎也不是问题。任何人都可以解释为什么我在程序中这么早就遇到内存泄漏问题吗?

4

2 回答 2

3

我遇到了同样的问题,当我使用调试模式时,与发布连接器 dll 链接。在调试模式下使用调试dll,可能没问题。

于 2011-09-08T08:47:51.100 回答
1

使用 auto_ptr 时必须小心。因为 auto_ptr 具有不寻常的复制语义(复制操作将所有权转移到指向的对象,而不是复制指针),所以很容易在您完成对象之前意外删除它。确保您的 auto_ptr<> 对象永远不会出现在赋值的右侧,并且您不会将它们作为参数传递给按值获取 auto_ptr 的函数。您没有显示足够的代码来彻底诊断它。

例如

// declaration for some function you've defined later
void some_user_function(auto_ptr<Connection> con);

auto_ptr<Connection> con(driver->connect("tcp://127.0.0.1:3306", "root", "root"));
some_user_function(con);
// At this point con will be a NULL pointer, and the Connection object it used to point
// to will have been deleted.
于 2011-07-25T22:09:59.490 回答