我们公司要定一种主要的开发工具,请大侠们指点……(实质性问题)(300分)

  • 主题发起人 主题发起人 sxzqcyj
  • 开始时间 开始时间
是一个DELPHI+VC+JAVA应该是最好的了。
 
数据库:
; ; 做C/S结构----Delphi,
; ; 做B/S结构----JSP或。net
应用程序:
; ;----VC.
 
你们公司正规吗?正规的公司在做前要讨论将来的开发方式,工具只是工具。面对
不同的项目选择合适的工具,任何工具都不能胜任所有的工作。看你们的项目是什么
来决定工具,我认为。做MIS PB,VB,DELPHI都差不多。要是做网络跨平台的程序
就要用JAVA,C#,.net。
VC++主要做底层的东西,比如驱动以及对速度有特殊要求的项目,比如电信。
罗里罗唆说了这么多也不知道你明不明白。
 
作MIS最好用Delphi,反正我觉得Delphi最好用了,呵呵,
要是所有的公司都用Delphi就好了!:)
 
帮delphi凑个数
 
>>为了现在、将来能更好、更快、更具经济效益的创作各方面应用的软件。
有源代码的当然用原来的源代友更好、更快、更快, 何必转用其它工具
但是如果真的要统一的话, delphi是最好的选择。
可是delphi也有局限性, 作底层驱动的开发是不行的, 要用VC。

b/S小型应用用ASP+SQL server,还有.net, 大型的用JSP+Servlet+Oracle
 
支持java 和 delphi
 
我们公司用 Delphi 做数据库和通信。
效率很高。基本上能保证大家都有空余时间学点别的。
 
《Delphi5开发人员指南》中老外对开发工具的选择有一个说明,好像是一个多边形,例如
效率、功能等等,你可以看一下!我推荐选择Delphi!
 
我赞成用DELPHI
 
□■■■■■■■■■□□□□□□□□■■■■■■■■■■■■■□□□□■■■■■■■□□□□□□□□□□■■■■■■■■■■■□□□□□■■■■■■■□□■■■■■■■□□□□■■■■■■■■■■■□□□□
□□□■■■□□□□■■□□□□□□□□■■■□□□□□□■■■□□□□□■■■□□□□□□□□□□□□□□■■■□□□□□■■■□□□□□■■■□□□□□□■■■□□□□□□□□□□■■■□□□□□□□□
□□□■■■□□□□□■■□□□□□□□■■■□□□□□□□■■□□□□□■■■□□□□□□□□□□□□□□■■■□□□□□□□■■□□□□■■■□□□□□□■■■□□□□□□□□□□■■■□□□□□□□□
□□□■■■□□□□□□■■□□□□□□■■■□□□□□□□□■□□□□□■■■□□□□□□□□□□□□□□■■■□□□□□□□■■□□□□■■■□□□□□□■■■□□□□□□□□□□■■■□□□□□□□□
□□□■■■□□□□□□□■■□□□□□■■■□□□□□□□□□□□□□□■■■□□□□□□□□□□□□□□■■■□□□□□□□■■□□□□■■■□□□□□□■■■□□□□□□□□□□■■■□□□□□□□□
□□□■■■□□□□□□□■■□□□□□■■■□□□□□□□□□□□□□□■■■□□□□□□□□□□□□□□■■■□□□□□□□■■■□□□■■■□□□□□□■■■□□□□□□□□□□■■■□□□□□□□□
□□□■■■□□□□□□□■■□□□□□■■■□□□□□■■□□□□□□□■■■□□□□□□□□□□□□□□■■■□□□□□□□■■□□□□■■■□□□□□□■■■□□□□□□□□□□■■■□□□□□□□□
□□□■■■□□□□□□□■■□□□□□■■■□□□□□■■□□□□□□□■■■□□□□□□□□□□□□□□■■■□□□□□□□■■□□□□■■■□□□□□□■■■□□□□□□□□□□■■■□□□□□□□□
□□□■■■□□□□□□□■■■□□□□■■■□□□□□■■□□□□□□□■■■□□□□□□□□□□□□□□■■■□□□□□□□■■□□□□■■■□□□□□□■■■□□□□□□□□□□■■■□□□□□□□□
□□□■■■□□□□□□□■■■□□□□■■■■■■■■■■□□□□□□□■■■□□□□□□□□□□□□□□■■■□□□□□■■■□□□□□■■■□□□□□□■■■□□□□□□□□□□■■■□□□□□□□□
□□□■■■□□□□□□□■■■□□□□■■■□□□□□■■□□□□□□□■■■□□□□□□□□□□□□□□■■■■■■■■■□□□□□□□■■■■■■■■■■■■□□□□□□□□□□■■■□□□□□□□□
□□□■■■□□□□□□□■■■□□□□■■■□□□□□■■□□□□□□□■■■□□□□□□□□□□□□□□■■■□□□□□□□□□□□□□■■■□□□□□□■■■□□□□□□□□□□■■■□□□□□□□□
□□□■■■□□□□□□□■■□□□□□■■■□□□□□■■□□□□□□□■■■□□□□□□□□□□□□□□■■■□□□□□□□□□□□□□■■■□□□□□□■■■□□□□□□□□□□■■■□□□□□□□□
□□□■■■□□□□□□□■■□□□□□■■■□□□□□□□□□□□□□□■■■□□□□□□□□□□□□□□■■■□□□□□□□□□□□□□■■■□□□□□□■■■□□□□□□□□□□■■■□□□□□□□□
□□□■■■□□□□□□□■■□□□□□■■■□□□□□□□□□□□□□□■■■□□□□□□□□□□□□□□■■■□□□□□□□□□□□□□■■■□□□□□□■■■□□□□□□□□□□■■■□□□□□□□□
□□□■■■□□□□□□□■■□□□□□■■■□□□□□□□□□□□□□□■■■□□□□□□□□□□□□□□■■■□□□□□□□□□□□□□■■■□□□□□□■■■□□□□□□□□□□■■■□□□□□□□□
□□□■■■□□□□□□□■□□□□□□■■■□□□□□□□□□□□□□□■■■□□□□□□□□□□□□□□■■■□□□□□□□□□□□□□■■■□□□□□□■■■□□□□□□□□□□■■■□□□□□□□□
□□□■■■□□□□□□■■□□□□□□■■■□□□□□□□□□□□□□□■■■□□□□□□□□□□□□□□■■■□□□□□□□□□□□□□■■■□□□□□□■■■□□□□□□□□□□■■■□□□□□□□□
□□□■■■□□□□□■■□□□□□□□■■■□□□□□□□■■□□□□□■■■□□□□□□□□■□□□□□■■■□□□□□□□□□□□□□■■■□□□□□□■■■□□□□□□□□□□■■■□□□□□□□□
□□□■■■□□□■■■□□□□□□□□■■■□□□□□□■■■□□□□□■■■□□□□□□■■■□□□□□■■■□□□□□□□□□□□□□■■■□□□□□□■■■□□□□□□□□□□■■■□□□□□□□□
□■■■■■■■■■□□□□□□□□■■■■■■■■■■■■■□□□□■■■■■■■■■■■■■■□□□■■■■■■■□□□□□□□□□■■■■■■■□□■■■■■■■□□□□■■■■■■■■■■■□□□□
□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□
□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□□
 
从技术上谈谈为什么
 
没人回答了吗
 
看你们单位的人员情况决定,如果用或者会用delphi 的人多,就用delphi会用java 的多
就用java 其它的以后发展...说实在的,如果以后公司发展了当然还会有新人进来,需要
什么样的人才找人好了。不适合的辞退也就好了
 
DELPHI ;---> ;JAVA
 
以前整理的东西,看看也许对你会有帮助
多种开发工具之间的比较
1、跨平台特性
VB:无;
PB:WINDOWS家族、Solaris、Macintosh,较强;
C++ Builder/Delphi:WINDOWS家族、Linux较强;
VC:无;
JAVA:所有能够运行JAVA虚拟机的操作系统组件技术支持,强。
2、组件技术支持
VB:COM、ActiveX较好;
PB:COM、Java Bean、Jaguar、User Object,使用:CORBA+ActiveX,较好;
C++ Builder/Delphi:COM、ActiveX、CORBA(本身自带CORBA中间件VisiBroker,有丰富向导),很好;
VC:COM、ActiveX、CORBA(没有任何IDE支持,是所有C编译器的功能, 需要CORBA中间件支持),较好;
JAVA:Java Bean、CORBA、ActiveX,好。
3、数据库支持级别
数据访问对象:
VB:DAO、ADO、RDO功能相仿,一般;
PB:Transaction、DwControl,可绑定任何SQL语句和存储过程,数据访问具有无与比拟的灵活性,很好;
C++ Builder/Delphi:具有包括DataSource、Table、Query、Midas、ADO在内的二十多个组件和类完成数据访问,好;
VC:同VB,但有不少类库可供使用,但极不方便,开发效率很低,较好;
JAVA:JAVA 、JDBC、 API,不同的IDE具有不同的组件,较好。
数据表现对象:
VB:DBGriD,与数据库相关的数据表现控件只有此一种,只能表现简单表格数据,表现手段单一,一般;
PB:DataWindow对象(功能异常强大,其资源描述语句构成类似HTML的另外一种语言,可在其中插入任何对象,具有包括DBGrid在内的数百种数据表现方法),只此一项功能就注定了PB在数据库的功能从诞生的那一天起就远远超过了某些开发工具今天的水平,很好;
C++ Builder/Delphi:具有包括DBGrid、DBNavigator、DBEdit、DBLookupListBox在内的15个数据感知组件,DecisionCube、DecisionQuery在内的6个数据仓库组件和包括QRChart、 QRExpr在内的20多个报表组建,可灵活表现数据,好;
VC:同数据访问对象,一般;
JAVA:不同的IDE具有不同的组件,比较著名的有Jbuilder、PowerJ、 VisualAge for Java,较好。
语句执行方式:
VB:将一句SQL串绑定到一个命令对象中,结果返回到ResultSet对象中自行拆取,一般;
PB:是一种真正的4GL语言,可随意直接嵌套SQL语句返回值被赋值到语句的变量中,支持语句级游标,存储过程和数据库函数,是一种类似SQLJ的规范,很好;
C++ Builder/Delphi:使用数据库组件或类完成SQL语句串的执行和提交,较好;
VC:同数据访问对象,一般;
JAVA:SQLJ、JAVA JDBC API,好;
4、系统底层开发支持
VB:调用API需申明,调用不方便,不能进行DDK编程,不可深入Ring0编程,不可嵌套汇编,一般;
PB:调用API需申明,调用不方便,不能进行DDK编程,不可深入Ring0编程,不可嵌套汇编,一般;
C++ Builder/Delphi:直接调用API,可进行DDK编程,可深入Ring0编程,可嵌套汇编,很好;
VC:直接调用API,可进行DDK编程,可深入Ring0编程,可嵌套汇编,很好;
JAVA:推出了JINI规范但不能对不支持JINI的设备编程,眼下并不实用,一般。
5、多媒体及图形图像开发支持
VB:可进行Direct API编程;调用OpenGL很不方便;自带少量图形图像处理控件,使用方便但功能一般;支持图像文件类型较少,较好;
PB:可进行Direct API编程;调用OpenGL很不方便;图形图像处理不方便但可调用API完成图形图像操作,也可借助控件开发;支持图像文件类型很多,一般;
C++ Builder/Delphi:可进行Direct API编程;调用OpenGL比较方便;自带丰富的图形图像处理组件及类,使用很方便且功能强大;支持图像文件类型一般,很好;
VC:可进行Direct API编程;调用OpenGL比较方便;自带丰富的图形图像处理类,使用不方便但功能强大;支持图像文件类型较少,好;
JAVA:很难调用Direct API和OpenGL;自带相当丰富的图形图像处理组件及类,使用不方便但功能强大;支持图像文件类型一般,好。
6、网络或Web开发支持
VB:Asp、VBScript,具有编写DHTML的简单IDE,编写静态页面非常方便;用于网络通讯的支持一般,较好;
PB:DynaSript、Web PB;提供了较多动态生成Web页面的用户对象和服务以及系统对象,非常适合编写服务端动态Web应用,有利于商业逻辑的封装;用于网络通讯的支持不足;静态页面定制支持有限,一般;
C++ Builder/Delphi:ISAPI、WININET API等各类网络或互联网API可自由而方便的调用;提供了ServerSocket、ClientSocket等三十余个组件及类,用来处理网络通讯控制,流处理,Mail、Email、FTP、HTTP等应用协议处理以及生成动态页面和商业逻辑的封装;功能强大,使用方便,很好;
VC:SAPI,WININET API等各类网络或互联网API可自由而方便的调用;提供CAsyncSocket等数量众多的类;功能强大但使用不太方便,好;
JAVA:不可直接调用API但内置非常多的网络及互联网功能;可利用Servlet API、Java Bean API以及JSP等协同开发功能强大的Web 应用;功能强大,对于某些IDE使用不太方便,很好;
7、开发模式
VB:控件开发模式(OCX),一般;
PB:组件开发模式(User Object),一般;
C++ Builder/Delphi:源代码组件开发模式(VCL),很好;
VC:应用程序框架开发模式(MFC),较差;
JAVA:框架开发模式(JDK下)+组件开发模式(IDE下),好;
8、面向对象特性
VB:差
PB:较好
C++ Builder/Delphi:很好
VC:一般
JAVA:非常好
9、开发效率
VB:较高
PB:很高
C++ Builder/Delphi:高
VC:低
JAVA:高
10、代码执行效率
VB:一般
PB:较高
C++ Builder/Delphi:很高
VC:很高
JAVA:低
11、帮助系统
VB:很好
PB:较好
C++ Builder/Delphi:差
VC:好
JAVA:较好
12、易学程度
VB:非常好
PB:好
C++ Builder/Delphi:好
VC:不好
JAVA:不好
13、使用人数
VB:很多
PB:较多
C++ Builder/Delphi:较多
VC:多
JAVA:不多
14、厂商财力
VB:非常强大
PB:比较强大
C++ Builder/Delphi:一般
VC:非常强大
JAVA:强大
15、发展潜力
VB:差
PB:一般
C++ Builder/Delphi:一般
VC:好
JAVA:非常好
16、基础语言广泛性
VB:很好
PB:一般
C++ Builder/Delphi:很好/差
VC:很好
JAVA:很好
17、结论:
VB:是新人开发与系统无关的综合应用程序的首选;容易使用和厂商财力很强是其仅有的两点优势;
PB:是开发大型MIS及各类数据库跨平台应用的首选;从数据库前端工具来讲甚至远远超过了Oracle
; ; 的Develop系列等专门的工具;从通用语言角度来讲功能也与VB等不相上下;多媒体和网络功能
; ; 与其他工具相比较弱;
C++ Builder/Delphi:是唯一一套能够同时适用于开发数据库应用、网络及Web应用、分布式应用、
; ; 可重用组件、系统软件、驱动程序、多媒体及游戏等所有软件的高效率开发环境;VCL源码基于
; ; Object Pascal是C++ Builder唯一的缺憾,基础语言不够通用和开发系统软件功能不足是Delphi
; ; 仅有的两点不足;
VC:从功能上讲除了跨平台应用外什么都可开发;从开发效率角度讲只局限于开发Windows系统应用、
; ; 可重用组件及驱动程序;
JAVA:适用于开发除了系统软件、驱动程序、高性能实时系统、大规模图像处理以外所有的应用。
18、综合评价:
VB:46
PB:53
C++ Builder/Delphi:67/61
VC:55
JAVA:59

不难看出从综合评价上来看,Delphi和VC是具有优势的,那么具体的它们之间的对比又是
如何呢?我们可以以一个程序员的角度,从技术水平、功能、性能、易用性、稳定性、发
展历程和前景等方面,以Visual C++ 6和Delphi 5为代表,尽可能客观地比较介绍Visual C++
和Delphi这两大主流开发工具的优缺点,其中将涉及到语言、应用框架、控件、编译和连
接、集成界面、调试、COM、数据库开发等。
1、基础语言:
有人认为Object Pascal是“玩具语言”,C++才是“专业语言”,这是不对的。单从语言
本身看,Object Pascal与C++属同一重量级。它们都是完全支持面向对象的语言,都扎根
于“历史悠久”的面向过程的语言。C++是由C发展而来的,Object Pascal由Pascal进化
而来。它们都有很强的灵活性,都有自己的特长和不足。比如说,Object Pascal不支持
多重继承、模板、操作符重载、内联函数定义、预处理、宏、全局静态类变量、嵌套类定
义,等等,而这些都是C++支持的。但同样地C++也不支持Object Pascal的虚构造函数、过
程嵌套、内置集合类型、内置字符串类型、“Finally”构造等等,在RTTI方面Object Pascal
也比C++做得好。但这些并不重要,因为可以通过其它方式达到同样的目的,比如C++可以
通过类扩展支持集合、字符串,Object Pascal可以通过“Interface”多重继承,等等。
关键是二者都可以很好地完成你手头的任务,这就够了。
但是,仅仅比较语言本身是不够的,还得看它们的被接受和流行程度,学习曲线,发展前
途,可移植性等,以及,很重要但常常被忽略的一点:与开发环境(指VC与Delphi)及其
应用框架的“磨合”程度。
VC和Delphi作为开发平台,很重要的一点就是提供了一个“无所不包”的应用框架:VC的
MFC和Delphi的VCL。MFC是用C++写的,VCL是用Object Pascal写的。当然,我们都知道,
C++的使用范围比Object Pascal要广得多,移植性也好得多。这本来就是优点,但很有意
思的是,正因为如此,微软写MFC时必须考虑最大限度减少对语言本身的改动,而把功夫下
在源代码级,以便能尽可能支持ANSI等标准,结果导致MFC的封装复杂而不直观。太多的宏
定义和含义模糊且自动生成、不得改动的注释使MFC乃至VC让很多新手望而生畏,不敢“下
水”深入学习。而Object Pascal几乎是Borland“专用”的,不必考虑“标准”问题,因
此Borland写VCL时就把全部精力放在了结构与性能上,结果语言与框架的磨合程度非常好。
VCL框架的结构清晰,VCL代码的可读性非常好。许多人说Delphi比较容易上手,也是这个
缘故。天下没有白吃的午餐。你要工业标准吗?你要可移植性吗?那么请面对MFC的“天
书”级代码吧。
2、编译和连接:
不同的语言带来的另一个不同是,编译和连接的速度的不同,以及执行速度的不同。Delphi
的编译和连接速度,毫不夸张地说,比VC快几十倍。即使把VC的Incremental Link选项打开
,Delphi的编译和连接速度仍比VC快好几倍。并不是说微软的编译器不行,这是由C++的复
杂性决定的。模板的处理、预处理和宏的展开都是很费时的。前文不是提到Object Pascal
没有模板、预处理和宏吗?这本来是缺点,但带来的一个好处就是编译速度极快。至于编译
完的二进制代码,在打开相同的优化选项的情况下,Delphi和VC执行速度并没有太大的差别。
为了克服编译的速度问题,C++编译器一般需要增强的连接器和预处理机制。但是预处理机
制仍然存在若干问题:
1)程序调试的断点行可能和代码行不同;
2)没有将最新的代码信息综合进去;
3)容易产生错误的逻辑;
4)因为读错文件头而很容易产生类似“Unexpected End of File”的错误。
两个编译器有个共同点是都能识别无用的“死”代码,比如一个没有用的函数等等。编译后
的程序将不包含这些多余的信息。Delphi在这方面作得更加出色。它可以让你在编辑器中可
视化地提示出那行代码是“活”的、那行代码是“死”的。这样你就能整理出最精简的代码
。Delphi在编译后将在左边显示一个小蓝点表示这行代码是“活”的。Visual C++做不到这
点。
Delphi编译后的可执行文件至少有200K(如果不使用VCL,仅仅使用WinAPI,文件的大小将
大大缩小)。但是Visual C++编程使用MFC编译后的可执行文件通常只有几十K,主要是因为
微软已经将系统运行库包含在Windows系统了(Borland公司曾经和微软协商这个接口,但是
微软利用操作系统的优势不愿意公开)。同样道理,使用BDE开发的的数据库程序必须附带
3-5M的额外系统文件,也是非常不协调的。
非常有趣的是,Delphi能够使用由C++ Builder创建的的OBJ文件,但是使用上受很大的局限
性。
  顺便提一下VC的“Edit and Continue”功能。在调试中,这个功能是可以大幅度节省
时间的,但仍不能和Delphi的闪速编译比。
最后,Visual C++的编译和连接时的错误信息比Delphi要详细和具体的多。特别是使用ATL
开发更加如此。
3、应用框架:MFC?有KFC流行吗?
应用程序框架(Application Frame),有时也称为对象框架。Visual C++采用的框架是MFC。
MFC不仅仅是人们通常理解的一个类库。(同样,Delphi的VCL也不仅仅是一个控件库,尽管
它的名字叫“可视控件库”。)你如果选择了MFC,也就选择了一种程序结构,一种编程风
格。MFC早在Windows 3.x的时代就出现了,那时的Visual C++还是16位的。经过这些年的不
断补充和完善,MFC已经十分成熟。但由于原型出现得比较早,MFC相比于VCL落后了一个时
代。尽管微软对MFC的更新没有停止,我也经常读到“只要Windows不过时,MFC就不会过时”
之类观点的文章,但就像Borland的OWL框架的淡出一样,MFC的淡出也是早晚的事。其实MFC
是和OWL同一个时代的产物。OWL已经不在了,MFC怎能不“居安思危”呢?如果MFC青春永驻
,微软的开发人员也不会“私自”开发出基于ATL的WTL呀。当然,WTL的地位不能和MFC比,
它并不是微软官方支持的框架,封装的功能也相当有限。但至少也反衬出了MFC存在的不足。
我以为,最能体现一个应用程序框架的先进性的是它的委托模型,即对Windows消息的封装
机制。对Windows API的封装就不用说了吧。大同小异,也没什么技术含量。如果高兴,你
也可以自己写一个类库来封装。但对Windows消息驱动机制的封装就不是那么容易的了。最
自然的封装方式是采用虚成员函数。如果要响应某个消息就重载相应的虚函数。但出乎我的
意料,MFC采用的是“古老”的宏定义方法。用宏定义方法的好处是省去了虚函数VTable的
系统开销。(由于Windows的消息种类很多,开销不算太小。)不过带来的缺点就是映射不太
直观。对于MFC,则是“太不直观”了。它的消息映射代码虽然是可见的,但“劝君莫碰”。
好在VC的ClassWizard可以自动生成消息映射代码,使用起来还算方便。但和VCL的委托模型
相比,MFC的映射方法就显得太落后了。而Delphi的Object Pascal因为没有“标准负担”,
语言引入了组件、事件处理、属性等新特性。由于功夫做在编译器级,生成的源代码就显得
十分简洁。似乎VC是“让框架迁就语言”,而Delphi是“让语言迁就框架”。
我想举一个对字符串操作的封装的例子来说明MFC和VCL的优缺点。在MFC中,CStringList类
有加入、获取、删除等功能,但VCL的TStringList类除了上述功能还有排序、从逗号分隔的
字串读入、流输入输出等功能。但同样的字符串替换功能,VCL的StringReplace要比MFC的
CString::Replace慢2~3倍。总的来说,VCL的封装比MFC更为高层,更为抽象,但不可避免
地带来的问题是某些部分执行效率比MFC略低。这就象低级语言(如汇编)的执行效率比高级
语言(如Basic)高,但编程效率较低。鱼和熊掌不可兼得嘛。
VCL比之MFC的另一优点是对异常处理的支持,而一大缺点是对多线程支持差。VCL的大部分
都不是针对多线程优化的。虽说VCL提供了简化多线程操作的类,但只是工作者线程
(Worker Threads)使用起来比较简单。如果线程要和界面打交道的话事情就变得麻烦了,
因为除了应用程序的主线程,任何线程不能访问任何可视的VCL部件。你不得不使用
Synchronize方法等待主线程处理它的消息,然后在主线程中访问VCL部件。而MFC就没有这
样的限制。
4、稳定性与完善程度:VC是老大哥
VC要比Delphi稳定和完善。VC的发展历史比Delphi长,微软的总体实力比Borland强。VC的
框架MFC经历了那么多年的发展和完善,功能非常全面,而且十分稳定,bug很少。其中你可
能遇到的bug更少。而且有第三方的专门工具帮助你避开这些bug。如此规模的一个类库,能
做到这一点不容易。不要小看了这一点,很多专业程序员就是为这个选择VC的。因为尽管
VCL比MFC的抽象程度高,封装较为高层,但由此带来的开发效率的提高对高手来说毕竟是有
限的。而如果你遇到一个怪问题,调试了半天,发现不是你的代码有错,而是VCL的bug,你
作何感想?虽说遇到这类问题的可能性很小,但对VCL的形象的影响可不小。Delphi的IDE太
占资源,启动速度太慢,和某些显卡驱动程序冲突,VCL中有bug,调试器不够健壮,对不稳
定的第三方控件没有防护措施……问题多多,在这方面Delphi不如VC。希望Borland能更上
一层楼。顺便说一下,我在网上看到有些人极言Delphi的不稳定,说几分钟出现20多次非法
操作。Delphi的确不如Visual C++稳定,但也不至于如此呀。我估计是那位朋友的Delphi装
了某些有问题的第三方控件,导致了Delphi的频频出错。
5、可移植性:立足现实,放眼未来
Borland正在开发Delphi的Linux版本,代号为Kylix。也许通过Kylix,用VCL构架编写的
Windows程序向Linux移植成为可能。但这只是可能。因为在目前Borland的兼容性工作做得
并不好。低版本的Delphi不能使用高版本的VCL组件(这还别去说它),而高版本的Delphi竟
然不能使用低版本的VCL组件。真是岂有此理,我很少看见软件有不向下二进制兼容的。如
果Windows 98不能运行95的程序,Windows 95不能运行3.x的程序,Win 3.x不能运行DOS程
序,你还会用Windows吗?如果Windows 95的程序必须经过重新编译才能在98下运行,98会
卖得那么好吗?“同门兄弟”C++Builder和Delphi也不能互相使用对方的组件,甚至同一套
VCL库的文件名也不一样。所以一个组件有for D1/D2/D3/D4/D5/D6/C1/C3/C4/C5这些不同版
本是常有的事,而且随着Delphi和C++Builder版本的升级可能还会增加。希望Borland能先
解决同门兄弟的兼容性问题。而微软的VC就没有这类问题。MFC1.0的程序也可以毫无障碍地
在VC6.0下编译通过。
6、集成界面:宏观与微观
就大处说,VC的集成界面是不如Delphi的。Delphi仅仅一个Object Inspector就可以将VC的
一堆Wizards比下去,何况它还有Code Explorer、ToDo List等。但从小处,又可以看出
Delphi的不成熟。比如“自动完成”功能的智能化程度和提示详细程度不如VC,响应速度
也没有VC快。
Visual C++所带的MSDN是一部“开发者的百科全书”,信息庞大,查询方便,这方面比
Delphi更加专业。很多帮助项都有源程序示范。
Delphi的OpenTools是完全面向第三方的开放系统,开发者可以修改很多Borland公司自
身的功能,从IDE的可扩充性上说Delphi更好。
7、调试:细微之处见真功
Visual C++和Delphi的调试功能都非常强大,同时都具有单步可视化调试、断点跟踪、运行
时改变变量、鼠标指向可以得到变量值等等功能。对DLL的输入输出也能方便的管理,能够
进行源码级别的调试。 相对而言,Visual C++能够更加方便地看到变量的变化情况,这包
括对结构可以展开成数据树,从而了解每一个变量的值,每一步调试,变化了的变量会加红
,从而使调试更加方便。另外,Visual C++的块内存察看比Delphi也要方便。
当然,Delphi也有很多体贴的细微之处,比如在线程调试的时候,Delphi能够很方便地察看
线程的变化,Visual C++确必须要弹出一个模式对话框。
8、数据库开发:Delphi一枝独秀
数据库支持是Delphi的强项。这主要体现在Delphi与BDE的无缝集成,以及Delphi提供的那
一大堆现成的数据库操作控件。这是VC望尘莫及的。目前Delphi支持BDE、ADO、InterBase
三种数据库访问方式。所有的方式都能拖拉到应用程序中实现可视化操作。正是因为Delphi
对数据库类的包装,使得用户操作数据库不像在Visual C++中必须从开始到最后都要干预。
明显地提高了开发速度。
在Delphi中使用WebBroker控件还能很方便地构造出基于数据库的Web页面,通过HTML管理
Web数据库。
Visual C++访问数据主要通过ADO和OLEDB,很多ActiveX控件也能添加数据库功能。但是没
有像Paradox这样的桌面数据库,Access相对太轻量级了。也许SQL Server是不错的选择。
9、COM:新技术的力量
COM是组件对象模型的缩写。它是OLE和ActiveX技术的基础,COM定义了一组API和一个二进
制标准,让不同的编程语言、不同平台的彼此独立的对象相互进行通讯。
COM是Microsoft制订的行业标准。但是,Delphi也为COM提供了强大的语言支持。支持接口、
variant、宽字符串功能。这些对COM的封装确实比C++更方便。比如在C++(没有类框架)进
行COM编程时,变体定义为oaidl.h文件中德VARIANT结构。要处理变体,必须手工调整
oleaut32.dll中VariantXXXX() API函数对其进行初始化和管理,如VariantInit()、VariantCopy()、
VariantClear()等等。
Visual C++实现COM编程有一种特殊的方法就是使用ATL。ATL使用Visual C++特有的多重继
承来实现COM接口。虽然不见得实现COM服务和控制更容易,但是ATL和最新COM技术的接口,
基于模板的构造都比Delphi强。ATL更有利于建立小巧、快捷的COM组件程序。
按照目前通用的观点,Visual C++应用到COM服务程序更有优势,Delphi应用到COM组件程序更合适。
10、昨天,今天,明天
技术的进步在很多时候是此消彼长的。当初Borland的Turbo C和Borland C++几乎是C/C++程序员唯
一的选择。微软的Quick C(现在还有人知道这个产品吗?)和Microsoft C/C++从来也没有成
为过主流。但Borland C++又流行了多少年呢?不久就被新崛起的Microsoft Visual C/C++压下去
了。于是Borland拣起了当年Turbo Pascal和Borland Pascal的辉煌(事实上Borland的成名
作就是第一个Pascal编译器),全力推出了Delphi。Delphi当初推出时被称为VB杀手,但VB
现在仍然活得挺好。毕竟微软是靠Basic起家的嘛,VB不是那么容易被打败的。Borland想了
想不和VB争了,使用Delphi的IDE和VCL配上C++语言,推出了C++Builder,又向Visual C++
的市场发起了夹攻。C++Builder似乎是个不错的折衷选择了?再仔细想想!C++Builder的优
点Delphi都有,但Delphi的优点C++Builder未必有。比如C++Builder的编译速度比VC还慢,
哪能和Delphi比?而且因为VCL是Object Pascal写的,C++语言和VCL磨合得并不好。C++Builder
的bug比Delphi还多,甚至Sample代码中还有错。VCL的部分功能不能使用,要靠嵌入pascal
代码访问。C++Builder可用的第三方控件远没有Delphi多。
11、鱼和熊掌:艰难的选择
选择一个开发工具依赖于很多不同的因素,每个人都能因为某种语言的某个缺陷而放弃学习
或使用这种语言。任何程序员都希望自己喜欢的工具能达到理想的境界,通过上面不完善的
比较,我想大家都有自己的看法。我们认为影响大家选择开发语言的因素主要包括:
①哪门语言更容易入门?
学习一种语言需要投入大量的时间和精力。开发程序的开发成本是值得考虑的现实。一个熟
练的Delphi资料库和一个熟练的VC程序员工作效率是一样的。但是,成为熟练的程序员必须
很快掌握一门语言的技巧。不幸的是,目前熟练的Visual C++程序员是十里挑一。相对而言
,Delphi更适合初学者。
②哪门语言有更多可继承的代码?
语言代码的可重用性是加快开发效率明显方面,从早期的过程、函数到现在的组件技术都是
朝这个目标在奋斗。这两种语言对代码重用的理解是不一样的,Delphi主要通过VCL控件来
实现代码重用,Visual C++实现起来就比较复杂。
③语言自身的本性。
就技术(主要指应用框架)来说,Delphi目前领先于Visual C++。但稳定性和健壮性的不足又
让我对Borland“想说爱你不容易”。而VC尽管发展到今日已十分完善,但MFC框架已是明日
黄花了。如果不使用MFC,目前又没有合适的替代品。
根据你的需要和实际情况做选择吧。实际上Visual C++和Delphi也不是单单竞争关系。它们
在许多领域并不重叠,甚至是互补的。到底怎样取舍,要根据你的项目特性决定。如果你开
发系统底层的东西,需要极好的兼容性和稳定性,选Visual C++吧。你可以只调用Windows
的各种API,不用MFC。如果你写传统的Windows桌面应用程序,Visual C++的MFC框架是“正
统”的选择;如果界面部分占这个应用程序代码比例较大的话,或者Delphi中有相关功能的
控件的话,Delphi是事半功倍的选择。如果你为企业开发数据库、信息管理系统等高层应用
(“高层”是相对于“低层/底层”而言的,不是说技术高级或低级。)而且有比较紧的期限
限制,选Delphi比较好。如果你熟悉的语言是Object Pascal,又不打算学复杂的C++,那么
Delphi几乎是唯一的选择。传统的观点是:Delphi适合编写Internet/Intranet、表格制图、
数据库操作、高级用户界面等等。Visual C++适合编写设备驱动、COM服务程序、科学计算、
控制台(Console)程序、WinCE的应用和一些小的工具等等。应用范围的不同要求好的程序
员精通这两门语言。
④语言的前景和可扩充性。
Delphi是Borland的旗舰产品之一,前景应当还是比较乐观的,而且Borland已经在向Linux
进军了,而微软还迟迟没有动作。遗憾的是,Borland公司Delphi的创始人已经跳槽到微软
去主持Visual J++项目了。但愿对Borland冲击不会太大。
微软的Visual C++的前景又怎样呢?Visual Studio 7.0就要推出了。这一版本将加强网络
开发的特性。看来微软虽然被判解体,开发实力可是一点没打折扣。
  另外,虽说MFC已稍显落后,但不是说它不值得学。事实上,不学MFC就等于没学VC。
利用MFC框架开发程序仍然是目前开发桌面应用的主流模式,而且还会保持相当长的时间。
微软公司CEO史蒂夫•巴尔默(Steve Ballmer)曾说,.NET流行还得等2-3年。那么,MFC至少
还有2-3年的生命空间。在技术日新月异的IT界,2-3年实在是很长一段时间了。好好把握吧
。即使你不使用MFC框架,花点时间看一下MFC的封装机制对你熟悉C++的OOP机制和Windows
底层功能也是很有好处的。而VCL的源代码是Object Pascal的,对C/C++程序员就没有这个
“额外”的作用了。
 
我来谈点看法:
理论上说,汇编能解决一切问题,无所不能。
但是人们为什么不选汇编呢?太难写,也太难读懂。
人们需要好懂、好写的开发工具,VB不错,可视化
界面,一度成为多数人的首选。可是很快就发现,
受到的限制太多。要是即功能强大又通俗易懂该多
好啊!VC似乎可以,但是:V太少,C太多。
Delphi成功了,目前没有比她更完美的了。
一流的可视化技术,强大的功能,严谨的语言,
把通俗和高雅天衣无缝的结合在一起了。
结论:Delphi
 
多谢terry_lzs的回答,这个正是我想要的,我想也是大家想要的。
对于terry_lzs的回答高手们还有补充吗?有不同见解吗?
 
在我看来,如果你们做的软件不是很大的话,Delphi是首选。
如果非常的大,要跨地区,跨平台,需要使用中间件,java当然是不二选择。
Pb,vb和delphi差不多,但是功能差了很多。
 
后退
顶部