《Windows编程循序渐进》——MFC封装机制详解

  • 单文档

这时候资源的Dialog里只有一个关于对话框:

运行下发现,这里如果选择的是CRichEditView:

如果点击另存为的话,这里会显示后缀:

我们来看它的类视图:

文档和视图有什么区别?一个文档只有一份,而视图可以有多份,比如对于一个TXT它是一个文档:

但可以打开N次:

下面我们来跟踪一下代码流程。先来看APP,这是表征这个应用程序的类,其构造函数如下:

其头文件中这个类的定义如下:

我们在APP文件中可以看到:

这里定义了一个APP自身的类,我们在这里下断点,并运行,等断到这里之后,我们单步步入,就来到了theApp的构造函数:

然而我们再单步步入时,就来到了CWinApp的构造函数:

这个CWinApp就是theApp的父类。这个类又有自己的父类:

于是我再单步步入就来到了CWinThread的构造函数:

再单步步入:

再单步步入来到:

这里啥都没干,单步执行又来到了它的子类中,然后又回到子类的子类中,这样,直到我们再回到:

实际上已经执行了好多步骤。我们单步执行,运行到这里:

却在watch窗口发现this指针指向的不是CWinApp而是他的子类:

Why?

可以参看:http://blog.csdn.net/ningyaliuhebei/article/details/42292147的解释。因为我们创建的对象是MFCFirstSineFile,他就会把创建的对象的地址,即theApp的地址作为参数传给theApp的构造函数,而theApp的构造函数调用时先调用CWinApp的构造函数,给CWinApp传递的参数就是theApp的地址。

下面通过类视图,来了解MFC结构。

CMainFrame中执行一些创建操作,比如创建工具栏、状态栏:

Alt+G进入第一个OnCreate还可以看到它会创建帮助:

再来看PreCreateWindow,里边有一个宏函数:

Go进入:

这个函数里边注册了窗体类。

创建完窗体之后还会挂钩:

这个Hook函数中挂钩了WH_CBT消息:

该消息触发条件是这样的: 当Windows激活、产生、释放(关闭)、最小化、最大化或改变窗口时都将触发此事件。

后边有个:

这里就是实现快捷键。在资源视图中,我们也能看到这些快捷键:

继续执行,执行到这里:

更新出了一个窗体:

但是被卡住不能动。执行:

整个窗体就显示出来了:

后边再继续走会看到:

这个函数就是彻底让窗体运行起来。我们来看其中的代码:

这里在不停的接收消息。上边的PumpMessage中就是执行的:

Run之后,这个程序就运行起来了。

时间: 2024-11-05 22:57:28

《Windows编程循序渐进》——MFC封装机制详解的相关文章

Linux内核模块编程与内核模块LICENSE -《详解(第3版)》预读

Linux内核模块简介 Linux内核的整体结构已经非常庞大,而其包含的组件也非常多.我们怎样把需要的部分都包含在内核中呢?一种方法是把所有需要的功能都编译到Linux内核.这会导致两个问题,一是生成的内核会很大,二是如果我们要在现有的内核中新增或删除功能,将不得不重新编译内核. 有没有一种机制使得编译出的内核本身并不需要包含所有功能,而在这些功能需要被使用的时候,其对应的代码被动态地加载到内核中呢?Linux提供了这样的一种机制,这种机制被称为模块(Module).模块具有这样的特点. 模块本

Android 接口回调机制详解

在使用接口回调的时候发现了一个经常犯的错误,就是回调函数里面的实现有可能是用多线程或者是异步任务去做的,这就会导致我们期望函数回调完毕去返回一个主函数的结果,实际发现是行不通的,因为如果回调是多线程的话你是无法和主函数同步的,也就是返回的数据是错误的,这是非常隐秘的一个错误.那有什么好的方法去实现数据的线性传递呢?先介绍下回调机制原理. 回调函数 回调函数就是一个通过函数指针调用的函数.如果你把函数的指针(地址)作为参数传递给另一个函数,当这个指针被用为调用它所指向的函数时,我们就说这是回调函数

Java反射机制详解

Java反射机制详解 Java反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法:对于任意一个对象,都能够调用它的任意一个方法和属性:这种动态获取的信息以及动态调用对象的方法的功能称为Java语言的反射机制. 1.关于Class 1.Class是一个类,一个描述类的类(也就是描述类本身),封装了描述方法的Method,描述字段的Filed,描述构造器的Constructor等属性    2.对象照镜子后(反射)可以得到的信息:某个类的数据成员名.方法和构造器.某个类到底实现

JavaScript 运行机制详解

JavaScript 运行机制详解——转载: 一.为什么JavaScript是单线程? JavaScript语言的一大特点就是单线程,也就是说,同一个时间只能做一件事.那么,为什么JavaScript不能有多个线程呢?这样能提高效率啊. JavaScript的单线程,与它的用途有关.作为浏览器脚本语言,JavaScript的主要用途是与用户互动,以及操作DOM.这决定了它只能是单线程,否则会带来很复杂的同步问题.比如,假定JavaScript同时有两个线程,一个线程在某个DOM节点上添加内容,另

Java多线程编程中Future模式的详解<转>

Java多线程编程中,常用的多线程设计模式包括:Future模式.Master-Worker模式.Guarded Suspeionsion模式.不变模式和生产者-消费者模式等.这篇文章主要讲述Future模式,关于其他多线程设计模式的地址如下:关于其他多线程设计模式的地址如下:关于Master-Worker模式的详解: Java多线程编程中Master-Worker模式的详解关于Guarded Suspeionsion模式的详解: Java多线程编程中Guarded Suspeionsion模式

Android内存管理机制详解 (zhuan)

http://www.2cto.com/kf/201212/175786.html 与windows内存区别 在Linux中经常发现空闲内存很少,似乎所有的内存都被系统占用了,表面感觉是内存不够用了,其实不然.这是Linux内存管理的一个优秀特性,在这方面,区别于 Windows的内存管理.主要特点是,无论物理内存有多大,Linux都将其充份利用,将一些程序调用过的硬盘数据读入内存,利用内存读写的高速特性来提高Linux系统的数据访问性能.而Windows是只在需要内存时,才为应用程序分配内存,

Android触摸屏事件派发机制详解与源码分析三(Activity篇)

PS一句:最终还是选择CSDN来整理发表这几年的知识点,该文章平行迁移到CSDN.因为CSDN也支持MarkDown语法了,牛逼啊! [工匠若水 http://blog.csdn.net/yanbober] 该篇承接上一篇<Android触摸屏事件派发机制详解与源码分析二(ViewGroup篇)>,阅读本篇之前建议先阅读. 1 背景 还记得前面两篇从Android的基础最小元素控件(View)到ViewGroup控件的触摸屏事件分发机制分析吗?你可能看完会有疑惑,View的事件是ViewGro

Android应用AsyncTask处理机制详解及源码分析

[工匠若水 http://blog.csdn.net/yanbober 转载烦请注明出处,尊重分享成果] 1 背景 Android异步处理机制一直都是Android的一个核心,也是应用工程师面试的一个知识点.前面我们分析了Handler异步机制原理(不了解的可以阅读我的<Android异步消息处理机制详解及源码分析>文章),这里继续分析Android的另一个异步机制AsyncTask的原理. 当使用线程和Handler组合实现异步处理时,当每次执行耗时操作都创建一条新线程进行处理,性能开销会比

《深入理解mybatis原理》 Mybatis初始化机制详解

对于任何框架而言,在使用前都要进行一系列的初始化,MyBatis也不例外.本章将通过以下几点详细介绍MyBatis的初始化过程. 1.MyBatis的初始化做了什么 2. MyBatis基于XML配置文件创建Configuration对象的过程 3. 手动加载XML配置文件创建Configuration对象完成初始化,创建并使用SqlSessionFactory对象 4. 涉及到的设计模式 一. MyBatis的初始化做了什么 任何框架的初始化,无非是加载自己运行时所需要的配置信息.MyBati