📄 05o015.htm
字号:
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<meta name="GENERATOR" content="Microsoft FrontPage 4.0">
<meta name="ProgId" content="FrontPage.Editor.Document">
<title></title>
<link rel="stylesheet" type="text/css" href="../../vckbase.css">
</head>
<body>
<div align="justify">
<table border="0" width="100%" class="font" height="57">
<tr>
<td width="27%" height="6" class="bigfont" bgcolor="#B8CFE7" align="center" bordercolor="#800080">
<font color="#800080">VC知识库(五)</font>
</td>
<td width="73%" height="6" class="bigfont" bgcolor="#B8CFE7" align="center" bordercolor="#800080">
<font color="#800080">www.vckbase.com</font>
</td>
</tr>
<tr>
<td width="100%" height="4" class="header" valign="top" align="center" colspan="2">
<hr>
</td>
</tr>
<tr>
<td width="100%" height="17" class="header" valign="top" align="center" colspan="2">
<p align=center><big>应用MFC开发高级应用程序</big></p>
</td>
</tr>
<tr>
<td width="100%" height="17" class="info" align="center" colspan="2">
苟建兵<br>
清华大学热能系(北京,100084)
</td>
</tr>
<tr>
<td width="100%" height="22" class="font" colspan="2">
<hr>
</td>
</tr>
<tr>
<td width="100%" height="5" class="font" colspan="2">
摘要:目前在Windows下开发应用程序的工具虽然很多,但是C/C++作为一种非常成<br>
熟和高效的开发语言在大型复杂项目的开发中仍然得到了广泛应用。为了减轻程序<br>
开发负担,提高开发效率,各种流行的C++都提供了类库,本文就是针对如何在<br>
Visual C++环境中使用MFC类库来开发高级程序所需要解决的一些问题进行了的探<br>
讨,重点讨论了利用MFC开发单文档多视应用程序和DDE应用程序的方法。<br>
一、使用C/C++<br>
随着Windows系列操作系统的日益普遍,传统的基于DOS编程逐渐转向Windows下编程<br>
已经成为必然趋势。目前在Windows下开发应用程序的工具很多,典型的如Borland
<br>
C++、Visual C++、Visual Baisic以及Delphi等等。每种开发工具都各有其特点,<br>
一般来讲用户可以根据自己的使用习惯和开发项目的性质来选择具体的开发语言。<br>
<br>
Visual Basic是一个被软件界称之为划时代的革新产品,该软件改变了人们开发<br>
Windows程序的方式,它采用交互式的可视化操作,使得人们开发Windows程序的每<br>
一过程都有直观形象的反馈,从而加速整个开发进程。Visual
Basic使得Windows程<br>
序设计人员不再只依赖于复杂的SDK编程,使得开发Windows程序非常容易,可以<br>
说,用户学习并使用VB来开发Windows应用的时间是最短的。Visual
Basic版本几经<br>
演变,目前已经发展到5.0。在4.0版本中,由于完全使用了面向对象的编程概念,<br>
同时具有Windows 3.1和Windows 95下的版本,因而使得其开发复杂程序的功能逐渐<br>
增强。VB5.0则抛弃了Windows 3.x的用户,只能在32位Windows中使用,据悉,该版<br>
本吸收了Delphi的成功策略,引入了本地代码(Native
Code)编译器,从而使得程序<br>
执行速度大大加快,克服了以往版本由于执行文件采用P-Code代码而导致运行速度<br>
慢的特点,根据微软的声明,该版本的采用本地代码编译后得到的应用程序在某些<br>
情况下执行速度较以往提高了10~20倍,执行速度可以直逼与采用Visual
C++编写的<br>
应用,而应用开发速度则是VB的强项,因此Visual
Basic 5.0非常具有竞争性。目<br>
前Visual Basic非常广泛地用于开发各种Windows程序,如数据库前端应用程序和多<br>
媒体应用等。但是,在作者看来,采用VB也有一定的缺点,原因有以下几点:<br>
1. Visual Basic来源于Basic语言,虽然经过微软的不断增强,但是仍然缺乏非常<br>
灵活的数据类型和编程策略,因而在开发一些项目必须的复杂数据结构遇到麻烦,<br>
如链表、图和二叉树等等。由于在中大型项目开发后期,开发工作不再以界面为<br>
主,而是在算法设计和底层软硬件工作,这就使VB开发项目的后期工作量大幅度增<br>
加,为了达到项目要求,经常需要再转向C/C++开发一些专用的动态连接库来解决问<br>
题。<br>
2. Visual Basic运行速度慢,前文讲过,采用P-Code代码虽然执行文件很小,但是<br>
在运行时需要解释执行,并且,它的运行必须有对应的VBRUN.DLL和所使用的VBX或<br>
者OCX支持。对于浮点操作密集或者循环嵌套很多的应用来说,VB没有采取特别的优<br>
化,因而执行速度远不如用C/C++和Fortran开发的应用速度快。VB
5.0虽然通过引<br>
入本地代码编译器大大弥补了这个缺陷,但是由于其只能运行于32位Windows环境因<br>
而在16位Windows上速度问题仍然得不到解决。虽然目前转向32位Windows的趋势非<br>
常强劲,但是不容忽视由于硬件的限制或者使用习惯等诸多原因,还有许多用户仍<br>
然在16位Windows上工作。在计算机十分普及的美国,96年使用16位Windows的用户<br>
仍然超过了使用32位Windows的用户,任何进行系统软件设计的人员都应该照顾到这<br>
些仍然使用16位Windows的用户。<br>
3. VB不能灵活地使用系统资源。熟悉Windows编程的人都知道,如果要直接访问硬<br>
件或者要编写对系统进行有效访问的应用程序,没有Windows
API函数的帮助则非常<br>
困难,但是令VB程序员失望的是,API函数是用C语言和汇编语言实现的,是为C编程<br>
准备的,如果要在VB里面使用这些上千个API函数则比较麻烦,特别是,如果设计人<br>
员不懂C语言则尤其困难。由于API函数的复杂性,而其本身不是为了方便VB编程而<br>
提供的,因此在VB里面调用API函数需要一定的技巧,这些技巧足够用一本很厚的书<br>
来表述。VB程序员可以从书店里找到好多本类似的书籍。可以说,任何一个VB程序<br>
员发展到一定阶段都需要与众多的API函数打交道。另外,由于VB不支持端口操作,<br>
因此,如果要编写类似数据采集等需要与硬件交互的程序则需要求救于C/C++语言。<br>
<br>
4. Visual Basic项目分发和管理困难,其原因同上讲的,VB应用的运行不能脱离VB<br>
的运行库和所使用的控件,因此,如果开发人员要将VB应用分发给用户那么一定要<br>
带上VB的运行库和所使用的控件,并且要保证正确安装,这就导致即使一个非常简<br>
单的应用也需要附带大量其它相关支撑库程序,对于VB
4.0及更高版本,由于大量<br>
的使用了OLE控件(在VB中称为OCX),其安装更为复杂。<br>
Delphi软件是国际宝兰公司(Borland)的得意之作,也是备受软件界推崇,与VB一<br>
样,它完全是一个交互式的可视化开发平台,支持Client/Server应用程序的开发,<br>
其最新版本2.0可以开发Windows 3.x、Windows 95和Windows
NT的应用程<br>
序。Delphi开发速度也非常快,与VB相比,由于具有本地代码编译器因此它产生的<br>
可执行文件执行速度大大加快。Delphi软件是一个非常有竞争力的软件,采用的是<br>
面向对象的Object pascal语言,支持硬件操作和API调用。但是由于采用的编程语<br>
言为Pascal,这种语言并不非常流行,许多程序设计人员完全不熟悉这种语言,因<br>
此极大地限制了该软件的使用,如果宝兰公司能够将Delphi软件提供的RAD开发机制<br>
引入到其Borland C++中,则可能会形成一个非常成功的产品(目前该版本已经推<br>
出,即C++ Builder,笔者注)。<br>
VB和Delphi引入的可视化开发方法还有一个共同的缺点就是各个版本之间的兼容问<br>
题。一般来讲,采用这些可视化开发工具开发的应用程序在移植到高版本时不会遇<br>
到太大困难,但是一旦往相反方向移植则困难重重,有时甚至不可能。C/C++语言则<br>
不具有这种局限性,各个版本之间的相互移植并不困难,高版本往低版本移植一般<br>
只需重建工程文件即可大功告成。<br>
综上所述,根据作者的观点,如果要开发一个大型复杂的应用程序首选的还是<br>
C/C++,特别是在16位Windows下。虽然这会使前期工作增加,但是在项目的中后期<br>
将逐渐会领略到其优越性和开发效率,其灵活高效的执行代码适合于对速度和应用<br>
程序之间的协同性要求很高的场合。纯粹基于Windows
SDK来开发Windows程序是一<br>
项艰巨的工程,值得庆幸的是目前各种流行的C/C++开发工具都提供了类库开发框架<br>
来简化整个开发过程而又不失其固有的灵活高效性,不同的开发语言所提供的类库<br>
开发框架不同,如Borland C++提供的OWL(Object
Windows Library)和 Visual C++<br>
提供的MFC(Microsoft Fundmental Class),这两种类库都封装了大量的Windows
<br>
API和Windows的开发元素而使得开发任务简化,两种类库各有其优点,据作者掌握<br>
的资料,采用MFC编写的应用程序执行代码更小,执行速度也更快,这大概是因为该<br>
软件的开发者是开发Windows操作系统的Microsoft公司的缘故吧,现在MFC正逐渐成<br>
为Windows下的类库开发标准,正被越来越多的其它C/C++编译工具所支持,如<br>
Watcom C++。使用MC类库同时配合Visual C++提供的AppWizard、ClassWizard和<br>
AppStudio可以大幅度提高开发效率。笔者在工作中积累了一些MFC的使用经验现在<br>
提出来供大家参考,希望对广大同行有所帮助,尤其是那些仍然致力于16位Windows<br>
编程的程序员。本文使用的Visual C++ 1.51编译器,但是其方法同样适用于其它<br>
VC++版本,包括Visual C++ 4.x。<br>
二、MFC编程综述<br>
采用MFC开发Windows程序之所以能够大幅度提高开发速度和效率主要是因为MFC在类<br>
层次封装了大量Windows SDK函数和典型Windows应用的缺省处理,这样,用户只需<br>
要较少的编程就可以实现自己的开发任务。如果在MFC基础上再配合Visual
C++提供<br>
的AppWizard、ClassWizard和AppStudio工具那么更可以大幅度加快开发进程。MFC<br>
提供大量的基类供程序员使用,常见的如CWinApp类、CFrameWnd类、CMDIFrameWnd<br>
类、CMDIChildWnd类、CView类、CDC类和CDocument类等等。通过从这些基类中派生<br>
出用户自己的类,然后重载特殊的几个函数就可以生成一个独立的应用程序。可以<br>
说,采用MFC编写Windows应用程序是非常方便的,虽然其学习过程并不简单,但是<br>
其提供的灵活高效性足以使任何Windows程序开发人员为之付出努力。如果用户不曾<br>
使用过MFC,那么用户可以通过附录中所列的参考书去学习MFC的强大功能。<br>
采用MFC应用框架产生的应用程序使用了标准化的结构,因而使得采用MFC编写的程<br>
序的在不同平台上的移植变得非常容易,事实上,MFC的16位和32位版本之间差别很<br>
小。MFC提供的标准化结构是经过众多专家分析调研后总结编写出来的,一般情况下<br>
可以满足绝大多数用户的要求,但有时用户也可以通过重载一些函数来修改其缺省<br>
的风格从而实现自己特有的风格,如自定义应用图表和灰色背景等。在MFC提供的文<br>
档视结构中,文档、视和资源之间的联系是通过定义文档模板来实现的,如:<br>
m_pSimuTemplate = new CMultiDocTemplate(<br>
IDR_SIMUTYPE,<br>
RUNTIME_CLASS(CSimuDoc),<br>
RUNTIME_CLASS(CMyChild), // Derived MDI child frame<br>
RUNTIME_CLASS(CSimuView));<br>
上中第一项IDR_SIMUTYPE就包括了视口的菜单,加速键和图表等资源,如果用户使<br>
用AppWizard来产生的应用基本框架,那么其也同时产生了缺省的图标,如果用户不<br>
满意缺省图标(实际上用户很少满足于缺省图标),只需要将缺省图标删除,然后<br>
编辑或者直接引入一个新的图标,在存储这一图标时只需要使用与被删除图标同样<br>
的ID即可实现替代。<br>
熟悉Windows程序开发的人都知道,在Windows上通过使用灰色背景可以增强应用程<br>
序的视觉效果,曾有人戏称,灰色是图形界面永恒的颜色。使用MFC产生的应用程序<br>
的背景缺省为白色,如果用户希望改变成灰色或者其它颜色,那就需要使用单独处<br>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -