具帮助你避开这些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 cal代码,但c++builder仍不能使用为delphi开发的vcl组件。所以一个组件有for d1/d 2/d3/d4/d5/c1/c3/c4/c5这些不同版本是常有的事,而且随着c++builder版本的升级可 能还会增加。希望inprise能先解决同门兄弟的兼容性问题。而微软的vc就没有这类问题 。mfc1.0的程序也可以毫无障碍地在vc6.0下编译通过。 再来看看它们的前景吧。实际上,技术的进步在很多时候是此消彼长的。当初bo rland的turbo c和borland c++几乎是唯一的选择。微软的quick c(现在还有人知道这个 产品吗?)和microsoft c/c++从来也没有成为过主流。但borland c++又流行了多少年呢 ?不久就被新崛起的microsoft visual c/c++压下去了。现在的c++builder又有后来居 上的态势,如果稳定性再提高一些,bug再少一些,有希望成为主流。但inprise的总体 实力不及微软,这也是无可争议的。从c++builder 5的release notes中的known issue s部分,以及它们的帮助文档的规模和质量都可以看出。(哪个同类产品的帮助文档能和 msdn比呢?)inprise公司应从netscape吸取教训,不要让c++builder成为第二个netsca pe communicator。(communicator也是一度技术领先,甚至曾占据了大部分的浏览器市 场,但似乎后劲不足,而且 6.0 pr1、2中bug多多,现在被ie压得抬不起头。)c++buil der是inprise的旗舰产品之一,前景应当还是比较乐观的,而且inprise已经在向linux 进军了,而微软还迟迟没有动作,难道非要到linux成燎原之势(或许已经成燎原之势了 )才会奋起占领这个新兴市场?似乎他们对linux的态度与几年前对互联网的兴起的反应 迟缓有些相似。但后来......唉,真希望inprise不要步netscape的后尘。c++builder是 一个很有前途的开发工具。遗憾的是,inprise公司delphi的创始人已经跳槽到微软去主
持visual j++项目了。但愿对inprise冲击不会太大。微软的visual c++的前景又怎样呢 ?visual studio 7.0不久就要推出了。不知能不能在保持稳定性的同时在技术的先进性 上赶上c++builder。另外,这一版本将加强网络开发的特性。看来微软虽然被判解体, 开发实力可是一点没打折扣。 就技术(主要指应用框架)来说,c++builder目前领先于visual c++。但多多少少 的不尽人意之处让我对inprise"想说爱你不容易"。而vc尽管发展到今日已十分完善, 但mfc框架已是明日黄花了。如果不使用mfc,目前又没有合适的替代品。wfc是支持组件 、属性和事件的,但那是visual j++里边用的;atl也很先进,但是用来进行com/activ ex开发的;基于atl的wtl也不错,可惜是非官方作品,也未必比vcl先进。微软最近提出 了c#(读作c sharp)语言方案,但那属于和java同一类的东西。看来是金无足赤啊。根据 你的需要做选择吧。实际上visual c++和c++builder也不是单单竞争关系。它们在许多 领域并不重叠,甚至是互补的。到底怎样取舍,要根据你的项目特性决定。如果你开发 系统底层的东西,需要极好的兼容性和稳定性,选visual c++吧。你可以只调用window s的各种api,不用mfc。如果你写传统的windows桌面应用程序,visual c++的mfc框架是 "正统"的选择。如果你为企业开发数据库、信息管理系统等高层应用("高层"是相对 于"低层/底层"而言的,不是说技术高级或低级。)而且有比较紧的期限限制,选c++b uilder比较好。如果你用的语言是object pascal,delphi是唯一的选择(如果gnu pasc al等免费编译器不考虑的话)。如果你原先用delphi(object pascal语言),现在想改学 c++,应当先用c++builder。熟悉的界面和相同的框架会让你的转轨事半功倍。 另外,虽说mfc已显落后,但不是说它不值得学。事实上,不学mfc就等于没学vc 。利用mfc框架开发程序仍然是目前开发桌面应用的主流模式,而且还会保持相当长的时 间。即使你不使用mfc框架,花点时间学习一下mfc的封装机制对你熟悉c++的oop机制和 windows底层功能也是很有好处的 作为程序员等级评判的标准之一c/c++(不管是mfc还是bcb)将 会让位给三种编程语言,的s平台上的c# 为什么这么说呢,我认为最大理由是目前的应用程序正在从基于独立的操作系统,传向 基于internet平台. 我们以前开发应用程序都是依赖于平台的功能调用,mfc,bcb都是这样.而现在日益火热 的internet编程却最不想关心的就是某一个平台的调用,譬如说要实现b2b的电子商务那 么就需要做不同平台的集成,如果我是程序员我最care的就是如何实现商务逻辑 而不是各种平台之间的通信和管理.那么我们最迫切需要的就是一种与各种平台调用无 关的语言,这中语言只注重程序逻辑的设计而不涉及平台的调用.而我们熟悉的c/c++却恰 恰不是为这个而设计的(赫赫这也不能怪c/c++在70年代谁能知道现在internet的情况呢 ).c/c++的最初设计目的是为了设计unix产生一种介于汇编和高级语言之间的一种开发高 效而性能不低的语言.他要比其他任何高级语言都要关心系统的物理结构,譬如一直是毁 誉搀半的指针.指针之所以强大就是应为涉及了系统物理内存的管理.他可以使得程序员 和系统之间成为一种半透明状态.但是就是这种半透明的状态让指针带来了更多的不稳定 性. c/c++在面向internet的编程中却无任何优势可言.跨平台的电子商务软件最害怕顾及 各种平台之间的天差地别的系统调用,最害怕时不时的由于内存泄漏而crash.c/c++的优 势在这里却成为了劣势.即使在windows平台上开发基于windows dna的solution 用的最多的还是vb做的dcom而不是vc的atl做的dcom,因为c/c++虽然高效但是太容易 出错,如果不是很小心的释放内存nt很快就会资源不足. java就是最先看到这种情况,他用jvm实现了平台无关用内存回收实现了稳定健壮.但是
相当多的c/c++程序员抱怨java太慢了.的确即使到java2速度仍然是一个大问题.我曾经 是一个c/c++坚决拥护者在许多论坛里和java程序员打笔仗.但是我逐渐意识到面对与in ternet平台而不是特定的操作系统的时候java的速度问题往往是一个小小的瑕疵.我们可 以想象那一个电子商务网站会用我们手头的pc做服务器,他们不是sun的e1000就是ibm的 risc6000.在这种平台上java这点速度问题只是a peice of cake.程序员只需要专注与商 务逻辑的编程,而不必要关心数组是否越界,对象内存是否释放更不需要关心是不是unix 和windows的系统调用不一样. 微软的c#可以说是一种java与c/c++的杂合体,他可以回收内存,可以平台无关.但是 他又可以实现一些java没有的功能譬如在标记的程序段内用指针自己管理内存,可以实 现操作符的重载等等.为什么要这样做我想也许c#还肩负了一定的面向操作系统开发的任 务例如winform.他基本上的思想和java类似,但是实现的方法又不一样他不通过jvm解释 中间代码,而是吧源代码编译成p代码然后通过cls库和jit在平台上及时编译为100%的本 地代码来执行.他的pe代码是独立于平台的,但是cls和jit却根据不同的平台而设计.因此 c#的平台独立有点类似于c/c++在不同平台上的移植使得c#比java来的更快.而且微软还 许诺cls和jit不仅针对c#还可以针对任何语言譬如pascal,smaltalk,basic因此将来有可 能所有的编程语言都是可以平台无关的(ms真是毒,所有的语言都平台无关java还有什么 优势呢,据说ms正在开发基于pascal smaltalk的asp+). xml很多人可能认为与html相类似的语言和c/c++,java,c#完全不在一个档次上的语言 .其实不然.我们知道不管是c#还是java都是通过统一地层计算来实现平台无关.那就必须 在性能上付出一点代价.而xml却能够实现不同的语言之间的调用.譬如说一个网占用jav a用bean实现一个出货功能,另一个网站用dcom实现一个入库功能 .如果这个网站需要实 现b2b,用一般的方式就是在他们之间写转换程序.而xml通过标记语言来描述各自的借口 特性.两端通过解析xml文本来实现互相的调用,无需任何中间转换程序 只要一张xml文本就能实现bean和dcom之间的通讯(要说清楚其中的机理,需要很多xml 概念如果有兴趣可以到xml或者去看看).目前ms的.ne t中最核心的技术soap就是完全基于xml的远过程调用. 介绍了那么多可能有点跑题,其实我最想说的就是21世纪的程序员应该从面向操作系统 的传统方法中走出来,学习一点如何面向internet平台编程的技术和概念.不要在无畏的 那种c/c++工具好之类的地方争论.我想不出一两年不管是bcb还是mfc都要淘汰, 到那个时候要争论的不是bcb好还是mfc好而是c#好还是java好.至于xml那是不管sun和 ms以至于世界任何大的it公司包括intel,hp都在奋力研究的技术,不学习可能就要被淘汰 .至于c/c++可能就会沦落到现在汇编的地位在某些系统效能敏感的地方还能见得到. 如果是编程语言的初学者那么我建议学习java同时关注c#,他们首先比c/c++简单没有 复杂的宏,指针,摸版等等让人摸不招头脑的概念.而且是完全面向对象,比c/c++的半调子 面向对象清楚的多好学的多.(我推荐目前学习java,毕竟c#还没有发布而且刚发布的bet a版的编译器要求高的吓人需要win2000 adv server没有128m内存的别想跑.话说回来c# 和java一摸一样没有什么太大的区别学好了java将来的c#将会信手拈来) 对于目前的windows下的编程者来说学习mfc的价值还是有一点的但是不是太大.至少可 以熟悉windows内在机理.但是我还是推荐关注一下c#将来的都是基于c#而不 是mfc.而且c#要比mfc简单的多实现一个同样的windows桌面应用c#的开发速度是mfc的两 到三倍而且几乎看不见性能的损失. visual studio 7.0中 vc将是一个次要的开发工具
最主要的开发工具就是c#和vb7.0.至于borland我想是不可能不跟着ms走至少windows平 台上是这样说不定明年就有一个c# builder出来作为borland的主打产品而不是c++buil der了.说一句玩笑话wenny说不定很快会把这里变成了
中国论文网(www.lunwen.net.cn)免费学术期刊论文发表,目录,论文查重入口,本科毕业论文怎么写,职称论文范文,论文摘要,论文文献资料,毕业论文格式,论文检测降重服务。