分享
 
 
 

对话框类对象的自销毁与外销毁

王朝vc·作者佚名  2006-01-08
窄屏简体版  字體: |||超大  

1 前言

MFC开发过程中起始有很多的细节指出可以作为一种模式,为今后的MFC开发工作做实际指导。本文介绍无模式对话框的内存管理。

1.1 约定

l 五号宋体斜字体表示:特定定义;

l 小五号Arial字体表示:VC++代码使用

l 五号楷体字体表示:类名称、类对象

2 正文

无模式对话框即Modeless Dialog。之所以称为无模式,是因为无模式对话框允许用户同时操作其他窗口,这样窗口就可以作为工具窗口在程序主要窗口之外提供额外的功能,分离了各个对话框的功能。最常见的是Windows操作系统层次的窗口,例如资源管理器,我的电脑,Word等。本文介绍的是更下一层次的窗口,例如Word的属性设置对话框。

无模式对话框的创建通过“三步曲”完成:new -> CreateWindow() -> ShowWindow(SW_SHOW)。无模式对话框的销毁通常有两种方法,一是在对话框的OnNcDestroy()函数中用delete this销毁自身内存,二是在外界用delete pdlg来清空内存。一下我们简称第一种方法为自销毁方法,称第二种方法为外销毁方法。

事实上两种方法创建的对话框的使用方式完全相同。他们的不同之处仅在于内存由谁来负责回收。

面向对象的C++的基本内存管理思想是由对象自身负责内存的回收,类的构造函数和析构函数正是这种思想的直接实现者。构造函数中应该包含所有对象中内存的分配逻辑,析构函数中包含所有对象中内存的释放逻辑。这样,不管对象中包含了如何复杂的内存存储结构,外界的管理方法都一样简单:对于静态对象,只需简单的对象声明即可,而对于动态对象,调用new/delete,就可以为对象分配/回收内存。

但关键问题是C++的指针特性带来了问题。指针特性带来了动态内存分配能力,但它是一把双刃剑,大部分的内存泄漏都与此有关。对于静态对象,构造和析构对象的代码都被作为可执行文件的一部分硬性编译到了可执行文件中,应用程序肯定会执行这一段代码,内存肯定不可能泄漏(除非系统有不测风云)。而动态对象必须由程序员负责调用delete来手动销毁,这是问题的关键所在,许多粗心的程序员常常会因为忘记了调用delete而导致内存泄漏而为此感到痛心疾首,或者因为多调用了delete后出现了严重的异常导致程序崩溃。我对那个Windows下的画着红色X号对话框是如此的记忆深刻,甚至我一看见他就觉得心惊胆战、浑身不爽。

如果你使用具有自销毁能力的对话框类创建模式对话框,你也同样将不得不面对这样的问题,那个红色X号对话框就会象恶魔一样缠着你。模式对话框使用DoModal()函数创建Windows窗口,在DoModal()返回的过程中,MFC 框架将发送NC_DESTROY消息到窗口,窗口在接受到该消息后执行窗口类的OnNcDestroy()函数。由于该类应用了自销毁方法,此时将调用delete this,也就是说窗口类对象的内存此时就已经被(自)清空了。这是第一次调用类的析构函数。然后,因为模式对话框是静态对象,应用程序将再一次执行析构函数……不用我说,你知道什么来了吧?那个画着红色X号的对话框!恐怖啊!

“哦哟!其实我对它应用自销毁方法,当然就是为了使用无模式对话框!”。也许你会这样为你的自销毁对话框类辩解。

呵呵,让我为你的这句话做个直译:自销毁的对话框类只能创建为无模式对话框。是的,对于你自己的程序,对于目前的程序,当然不需要考虑这么多。

但是,更重要的原因是,使用了自销毁,一旦程序需要这个对话框表现为模式对话框,你将不得不直接修改该对话框类的代码。如果你把该类作为二进制的组件交给别人使用,那么对于那些需要使用模式对话框的人,这个类将毫无用处。

如果使用外销毁方法,那么这些问题都是不存在的,你需要记住的是一定要手动调用delete pdlg。这样虽然多了无数次的delete pdlg调用,但是你可以清楚的知道什么地方创建了它,然后又在什么地方销毁了它,这一切都被你牢牢地掌握着。而且,你可以根据不同的需要,利用该对话框类创建模式和无模式对话框,这事实上提高了程序的灵活性和可扩展性。

3 结论

自销毁对话框类限制了对话框的创建模式,降低了程序的灵活性和可扩展性。而外销毁对话框类没有这些限制。现代程序的编写风格更加重视程序扩展性和灵活性,所以,我建议在程序中使用外销毁方法。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有