|
|
| VisualC++与Delphi/C++Builder之比较及未来的发展前景之我见 |
|
+Builder 3以上版本可以原封不动直接编译Visual C++程序,很多人认为这是C++Build
er的兼容性好,实际上很大程度应归功于MFC的兼容性好。微软辛辛苦苦用标准方法写M
FC,却为对手制造了方便。不知他们作何感想?而因为C++Builder对语言作了扩展,VC
不能编译C++Builder的程序。看来在这方面VC要输给C++Builder了。而且VCL所支持的组
件、属性等都是MFC所缺乏的特性。虽然VC也能支持组件,但要通过AppWizard先生成一
个"包裹"类(wrapper),不如VCL来得简洁。有很多人使用C++Builder就是冲着控件板
上那一大堆组件来的,VC虽然能使用的组件也很多(也许不比C++Builder少),但由于不
方便而对RAD程序员没有吸引力。
C++Builder的VCL比Visual C++的MFC先进的另一个特性是异常处理。但令人啼笑
皆非的是,它的异常处理代码有bug,有时会无端抛出异常。不知道在最新的版本中有没
有改正了。而VC的框架MFC也不是一无是处。经历了那么多年的发展和完善,MFC功能非
常全面,而且十分稳定,bug很少。其中你可能遇到的bug更少。而且有第三方的专门工
具帮助你避开这些bug。如此规模的一个类库,能做到这一点不容易。不要小看了这一点
,很多专业程序员就是为这个选择VC的。而C++Builder的VCL的bug就相对较多了,而且
有些它自己带的示例程序都有错误。看来Inprise还有很长的路要走。
再从它们的易用性比较。VC有ClassWizard、SourceBrowser等一系列工具,还附
带Visual SourceSafe、Visual Modeler等强大的工具,易用性非常好。(VC自带建模工
具Visual Modeler,也许说明了它才是工程级的开发平台,与C++Builder的定位不同。
)它所带的MSDN这部"开发者的百科全书"更是让你"没有找不到的,只有想不到的"。
而且它的AutoComplete之类小功能也比C++Builder要体贴。C++Builder的新版本虽然也
提供了这一功能,但它的提示要等好几秒才出来,有时你不经意间把鼠标停在某一处,
也要等硬盘响好几秒,这可是在566Mhz的赛扬II上呀。不要笑我琐碎,有时一个开发工
具的成熟和易用,就是从这些小地方体现出来的。C++Builder作为RAD工具,理应强调易
用性。但与VC相比还显出不成熟。这是不应该的。
再来看看它们的可移植性。Inprise正在开发C++Builder和Delphi的Linux版本,
代号为Kylix。也许通过Kylix,用VCL构架编写的Windows程序向Linux移植成为可能。但
这只是可能。因为在目前Inprise的兼容性工作做得并不好。C++Builder可以编译VC程序
还要多谢微软使用标准方法写MFC,而它自己各个版本之间兼容性却不太好。低版本的C
++Builder不能使用高版本的VCL组件(这还别去说它),而高版本的C++Builder竟然不能
使用低版本的VCL组件。真是岂有此理,我很少看见软件有不向下兼容的。如果Windows
98不能运行95的程序,Windows 95不能运行3.x的程序,Win 3.x不能运行DOS程序,你
还会用Windows吗?如果不是C++Builder的其它某些方面太出色,光是这个向下不兼容就
足以让我抛弃它。而且虽说通过捆绑编译器,C++Builder可以编译Delphi的Object Pas 上一页 [1] [2] [3] [4] [5] [6] 下一页
|
|
|
|
|
|
|
|
 |
|