这是几天上午调程序时遇到的问题。先来看有错误的代码:
void TestSelect(CMysqlDBTools myDBtools)
{
vector<StringMap> info;
string query = "select bc_id, b_title from board";
myDBtools.SetQuerySQL(query);
myDBtools.ExcuteQuery();
info = myDBtools.GetVecRecords();
for(int i=0;i<info.size();i++)
{
cout<<info[i]["bc_id"]<<":"<<info[i]["b_title"]<<endl;
}
}
int main()
{
CMysqlDBTools myDBtools("172.30.27.188", "user", "password", 3306);
myDBtools.Connect();
myDBtools.SelectDatabase("hwalk_test");
TestSelect(myDBtools);
return 1;
}
先得到数据库联机工具,然后测试此工具的select功能。myDBtools通过值传递。整个输出执行过程没有问题,但程序结束时报内存读异常。
经分析,原来是~CMysqlDBTools()调用了两次--TestSelect()结束时调一次,main()结束时调一次,第二次调用的时候由于指针已经指向了NULL,所以报错。
可以看出,C++中通过值传递对象参数时,对象为浅层拷贝,对象里的指针指向相同的地址,缩影应该引起注意。
上面的程序做如下任意一种改动,通过指针或引用传递参数就没有问题了。
指针:
void TestSelect(CMysqlDBTools* pMyDBtools)
{
vector<StringMap> info;
string query = "select bc_id, b_title from board";
myDBtools->SetQuerySQL(query);
myDBtools->ExcuteQuery();
info = myDBtools->GetVecRecords();
for(int i=0;i<info.size();i++)
{
cout<<info[i]["bc_id"]<<":"<<info[i]["b_title"]<<endl;
}
}
int main()
{
CMysqlDBTools myDBtools("172.30.27.188", "user", "password", 3306);
myDBtools.Connect();
myDBtools.SelectDatabase("hwalk_test");
TestSelect(&myDBtools);
return 1;
}
引用:
void TestSelect(CMysqlDBTools& myDBtools)
{
vector<StringMap> info;
string query = "select bc_id, b_title from board";
myDBtools.SetQuerySQL(query);
myDBtools.ExcuteQuery();
info = myDBtools.GetVecRecords();
for(int i=0;i<info.size();i++)
{
cout<<info[i]["bc_id"]<<":"<<info[i]["b_title"]<<endl;
}
}
int main()
{
CMysqlDBTools myDBtools("172.30.27.188", "user", "password", 3306);
myDBtools.Connect();
myDBtools.SelectDatabase("hwalk_test");
TestSelect(myDBtools);
return 1;
}