使用C++实现SDK之WebBrowser容器 系列的一个补充. 关于GetHtmlDocumentX()

之前的文章 "http://blog.csdn.net/norsd/archive/2008/09/13/2921389.aspx" 实现了一个WebBrowser.

 

但是万物总不是完美的, 最近有网友问, GetHTMLDocumentX 系列函数的实现,是否需要Release.

 

当时我回答不需要. 我是这样考虑的:

 

WebBrowser 类只提供一个(系列)  IHtmlDocumentX* 指针, 在析构的时候 Release. 这样的实现听起来不错,实际运行也似乎没有问题.

 

非常巧合,最近终于发现问题.

 

考虑这样的情况:

 

 

1.打开页面  nothere.html

2.如果这个页面无法打开,WebBrowser会不断重试

3.这时候如果立刻跳转到其他页面,这时候WebBrowser会产生一个新的 IDocument 对象

 

这时候我们的 IHtmlDocumentX* 指针指向的还是之前的 nothere.html

只有我们 get_Document 才能得到当前页面的 document.

 

所以代码应该改成这样:

p.s: IHTMLDcoumentX  , 表示 IHTMLDocument , IHTMLDocument2 , and so on.

 

posted on   norsd  阅读(176)  评论(0编辑  收藏  举报

编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· 葡萄城 AI 搜索升级:DeepSeek 加持,客户体验更智能
· 什么是nginx的强缓存和协商缓存
· 一文读懂知识蒸馏

导航

< 2009年3月 >
1 2 3 4 5 6 7
8 9 10 11 12 13 14
15 16 17 18 19 20 21
22 23 24 25 26 27 28
29 30 31 1 2 3 4
5 6 7 8 9 10 11
点击右上角即可分享
微信分享提示