c++ ado _RecordsetPtr 记录集使用问题

chao360559040 2011-12-17 12:46:42
c++通过ado操作数据库。
代码:
_RecordsetPtr rs;
HRESULT hr = rs.CreateInstance(__uuidof(Recordset));
if (FAILED(hr))
{
return PE_FAIL;
}
创建记录集后,执行 rs = connection->Open(sqlstr); ,通过connection连接对象来返回记录集,返回后,发现rs的地址和原来的不一样,这样是不是造成了内存泄漏。即 HRESULT hr = rs.CreateInstance(__uuidof(Recordset));
创建的记录集并没有释放。
我不写HRESULT hr = rs.CreateInstance(__uuidof(Recordset));这一句,程序也能正常运行,是否有问题?
...全文
97 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
柯本 2011-12-17
  • 打赏
  • 举报
回复
HRESULT hr = rs.CreateInstance(__uuidof(Recordset));

rs = connection->Open(sqlstr);
是连接ADO不同的方法,你把它们用在了一起,问题应该不是很大(没测试过),但一般不这样用
如果用
HRESULT hr = rs.CreateInstance(__uuidof(Recordset));
后面应该是写
rs->Open(sqlstr);
如果用
rs = connection->Open(sqlstr);
就不要用
rs.CreateInstance(__uuidof(Recordset));


chao360559040 2011-12-17
  • 打赏
  • 举报
回复
恩 明白了 谢谢了!

64,654

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧