回 帖 发 新 帖 刷新版面

主题:一个老VFP爱好者说说他的VFP之旅

我2000年开始苦学VFP,主要参考的书是《VisualFoxPro6.0中文版入门与提
高》[清华大学出版社]和《VisualFoxPro6.0入门与应用实例》[李俊德编著 清华大学出版社]2本书。尤其是后一本书,完全可以称的上是当今VFP学习中的经典书籍,你看了它,才知道以往所看的一切VFP类的书和教程都是狗屁!不可能再有书能超过它了,我也完全是靠了它才真正进入并进而掌握VFP的。如果你打算在VFP方面有所长进,非买这本书不可!
     我同时也学了VB6.0、Delphi7.0、PowerBuilder8.0和ASP,基本上都是学习做管理系统。总的感觉是:VB的确简洁明快,功能不凡,我现在有写小程序还在用它做;Delphi很庞大,也比较罗嗦,不过功能强大,让人惊叹,堪称完美,但也复杂,不如VB简单;PowerBuilder8.0简直是狗屁,罗嗦复杂,莫名其妙,功能却幼稚可笑,真不懂一些人为什么还在那里硬撑着说它强大,学它简直是浪费生命,根本不能与VFP相比;ASP很有趣,实际需要掌握的东西很少,但功能强大,简直无所不能,在里面只有想不到没有做不到的,不过要有一点VB的基础编程知识,尤其是它是网络性的编程,前景广阔,我现在正在玩它。:)
    最后说说VFP。说实话,我心情很复杂,我曾经是VFP的狂热拥护者,progranfan是我经常上的网站,我在CSDN的VFP论坛也经常出现,为VFP与不少人打过嘴官司,你可以到那里看看我的一些帖子的。VFP入门并不简单[当然入门后就能轻松掌握了,它要人上的是陡坡,不象其它编程语言那样进门容易,而达到掌握却是长途漫漫],如果你以前从未学过VB之类的编程语言,你可能还不以为然,如果你学过,你简直觉得VFP语言实在糟透了,莫名其妙不说,还很罗嗦,单个表单必须放在同一目录下,不想遭这个罪的就要搞表单集,界面弄的一塌糊涂;在表单的启动处还要对窗口进行一些莫名其妙的设置,开始还要搞什么READ EVENTS ,结束要CLEAR EVENTS ,不然编译出来的EXE文件鬼影一闪就不见了(我曾为这个,将别人的原代码一行行删除排查,花费了3个月才最终搞清楚);还有菜单这种在Deiphi中做起来简直象好玩似的东西,在VFP中要用编辑器,如果要出现在表单上还要搞什么顶层表单;每行程序都要搞this.text1.text这样罗嗦的语法。最终做出来的东西是:界面象玩具,幼稚可笑;莫名其妙的出现错误提示,总是某个变量出现错误,容错功能实在很差;前端界面与后端数据库一损俱损,一荣俱荣,哪个出了问题,包括索引文件出了问题,整个系统就报废了,而重装则意味着曾经输入的数据作废。这种客户端与数据库缠在一起,既是VFP的特点和优点,也是其致命弱点,而用VB+ACCESS、Delphi+ACCESS或SQL2000做的管理系统,客户端界面不完善,重做编译安装,数据库不受影响;数据库出了问题,只需对其进行改造,客户端界面不受牵连。通过ODBC或BDE或OLEDB Privider这根“线”将客户端界面和数据库这两颗“珠”联系起来,其中一者坏了,顶多就是解开“线”重新连接一次罢了。所以,学了VFP,最终还是回走向VB+ACCESS、Delphi+ACCESS或SQL2000做管理系统这条路,VFP不过是热了一下身。也正是这样,注定了VFP是一个悲剧性的东西,而其实,它却的确是一个非常有特色,非常方便快捷的数据库系统开发工具。
    别的不说,就进入VFP之快,就让人很爽,再看看Delphi之类的,我操,等的老婆都要生完孩子了。VFP做出来软件体积很小[只有VC++做的才可与之相比],而且还能在不同系统平台上运行[比起另一跨平台的JAVA老太太它姥姥似的浪费人民生命的奇慢无比,简直就象奔驰之与蜗牛],运行速度奇快,搜索数据之快天下第一,它独特的过滤和查找功能没有哪种语言能及。在熟练掌握语言后,开发速度也非常快;如果不怕麻烦,有创意和决心,它最薄弱的界面问题也是可以得到很大改观的。再看看它很具特色的“自定义属性”、“自定义函数”、“存储过程”,自定义库等,独特而实用,此外非常底层化、精细化的语言,完全掌握后,你会对数据库系统的开发有更清晰完整的认识,而不是除了只会白痴一样的搬一大堆控件来实现功能外,连行正确的程序都编不出来。想真正的通过程序而不是控件来实现并明白数据库系统的工作原理,VFP比Delphi都要强。不过VFP的并不完全面向对象也限制了它功能大发挥,但对于并非比尔·盖次的我们老百姓程序员或爱好者来说,这种限制我实在感觉不到。
    VFP的优点实在太多,我一下子也说不完,何况大家也没那么多时间听了。
    现在我改用Delphi+SQL2000或ASP+ACCESS2000或SQL2000做管理系统了,原因很多,相信许多学VFP的人学到一定程度,基本上也会走我这条路的,到那时,或许我今天没说的东西,他们心里已经明白了。不过,有时间和兴趣,我还会用VFP做一些东西,或建议别人学VFP的,这样做,或许还是因为不能最终忘情于它吧。   hbgth  2004年6月8日下午于武汉

回复列表 (共111个回复)

41 楼

有一点我至今都没搞懂:既然每个程序都要有“READ EVENTS”为什么微软不让系统编译时自动加入?

42 楼

楼主所说的我也有同感,
VFP、VB、Delphi这三种语言中,VFP对数据库控制最直接、直观、快,Delphi+ACCESS如果数据库使用了索引的话,记录数>3000时就变慢,>7000时就是蜗牛了,VB蓖也是一样VB.NET没用过。
VFP的自由表最容易出错,我用自由表来保存查询结果要经常刷新此表,每过一两个月就出错,解决为法就是用程序生成自由表.
在VB中我有个SQL搞不清"SELECT *  FROM 数据库 WHERE 数据库.日期 = date() "时出错,
说是数据类型不对之类的,数据库的日期字钝是日期型的,有那位高手可以帮帮忙啊。

43 楼

还有请看看这个VFP程序有什么问题

*************************************
PUBLIC _prnfile as String
PUBLIC b
b="dfgbdgh"
SET TEXTMERGE ON
SET TEXTMERGE NOSHOW
SET TEXTMERGE TO (_prnfile)
\ <<PADC(b,30)>>
\ <<CHR(12)>>
WAIT CLEAR
SET TEXTMERGE OFF
SET TEXTMERGE TO
*2.
RUN /N7 prgs\copyfile.bat (_prnfile) && 在此出错,提示"RUN|!命令失败,系统找不&&到指定的文件"

*3.copyfile.bat 文件如下
COPY %1 prn
用于控制打印机的有谁可以帮帮忙

44 楼

楼主:
    读了你的贴子,对VFP产生了更加强烈的学习兴趣。但不知如何学?我不懂英语,加上以前没有学过任何一种语言,能学会吗?[em18]

45 楼

VFP入门容易呀!ORACLE比较专业!SQL SERVER 专业、很多编程软件都要用到SQL语言!

46 楼

VFP很容易学的只要动手能力强,乱弄也会有收获的,买一本基础的书来照着做呗!信不?以前会一的,在VFP中不一定用得上的只懂一个流程而已!

47 楼

我以前用过dBase,现在又在啃VFP,我自己工作中用数据库比较多,所以还是VFP比较适合自己.学习中我感到还是多看看人家的源代码,那样学得才透彻!

48 楼

你说的很有道理。其实最重要的是看自己觉得什么对自己最有用,最适合自己。没必要为所谓“专业”、“高深”之类的硬是去死啃VC++,用它来做数据库,那是费力不讨好的事。:)有现成的VFP就可轻松搞掂。

49 楼

hbgth楼主你好:
   快一个月没见了,好否!
   我有个想法,因为VFP运行速度的问题,我现在想在业余时间学DELPHI7我是侧重于做企业管理系统的,你对DELPHI7的感觉如何.
                     PONY

50 楼

各位好,我刚开始学习VFP,但初看起来一点头绪也没有,觉得很难,希望大家能帮助我,谢谢!我现有一个问题想请教一下:我公司现想作一个工资计算的模块,主要有人员姓名、规格、单价、工资、耗料;规格每月都要增加或减少,请问怎么作才能比较简单并且实用?QQ:117846288;email:luck688@163.com

我来回复

您尚未登录,请登录后再回复。点此登录或注册