一个C++程序员的Delphi学习笔记(2)

原创 2001年09月19日 01:01:00

一个C++程序员的Delphi学习笔记(2)

三 VCL

   《从入门到精通》,作者的安排可真大胆。不先讲如何在Form上摆控件,倒自VCL讲起。我佩服作者的气魄,直直的深入到问题的核心,剔筋去肉,先将脉络端到你的面前。要知道,这有着失去很多读者的危险。

1.TObject,万类之源。RTTI信息就放在这里了,这算是单根单继承实现上的便利吧。

2.一个细节:TButton.InstanceSize=504!真够浪费的。算法分析中常讲以空间换时间,这该算以空间换宜用性吧。

3.作为TPersisitent的子类,TComponet拥有流化能力。IDE就用其将属性写入DFM文件中。

4.TPersisitent委托TFiler和TStream两个辅助类来具体实现流化。具体实现中包括自RTTI中读出子类所有拥有的属性,使流化对程序员透明。

5.非窗口控件?相信是对效率低的一种补偿。

6.Componentsk中包含窗体所有上的控件,即使他们的Parent为别的组件容器,其Owner也是Form.

7.Owner和Parent,两个易混淆的概念。我的理解:Owner是对象的持有者,Parent是对象的呈现者。

8.窗体元素没有进行封装!带来访问的便利性的同时,也留下混乱的隐患,特别在大型工程中。

9.控件位置的坐标原点对应Parent的客户区,这加强了我的信心:Parent是对象的呈现者。

10.Frames,窗体继承的有力竞争者。其本质是以聚合代替继承。昨天有朋友提出:"我觉得聚合是不可以取代继承的"。的确,聚合不可能完全代替继承,但在两者同时适用的条件下,应该选择耦合较为松散、封装更为完全的聚合。具体到Frames和窗体继承来说,我感觉在不涉及多态时,是应该选用Frames的。

11.Delphi提供的容器类,与C++的STL相比,从弹性到效率可就差远了,还容易出现类型安全问题。还好Delphi的RTTI机制强大,可以略补不足。这该是没有模板机制的副作用:整个的泛型思想都用不上。

   其实作者还是很为初学者着想的:并没有深入VCL。虽有点意犹未尽,但作为初学的我,也该是知足了。

四:标准组件
  
    其实很多Delphi的使用者,都是看中众多的VCL组件支持。有朋友对我前文所说"其实属性和事件并非面向对象的必要元素"表示不敢苟同,我相信他是混淆面向对象和面向组件了。在我的记忆中,面向组件是面对对象的扩展,其本质虽仍是面向对象,但为之添加了众多的辅助特性,其中就包括属性(不是C++的"属性")和事件。

1.Form的Components,GroupBox的Controls,ListBox的Items,Delphi还真是喜欢用数组容器来表达组织结构。

2.还有sleected数组,ItemEnabled数组,哦,值也是通过Items数组的对应项来存储的。

3.Drag-Drop。看到书的标题,不由的就想到IDataObject、IDropSource、IDropTarget几个接口。其实Delphi的拖放要简单很多。就我的了解,本质是一个Drop通知,不像Com会将数据本身包装好传送。这该是不需支持跨进程Drag-Drop的原因吧。

4.菜单不再做为资源出现,呈现给应用程序员的,是其包装后的TMenuItem和组织成嵌套形式的Items。两个优点:a)纯一,不再有菜单资源需程序员理解。2)在包装层中括展菜单功能极为方便,并对程序员透明。为此,ImageList也进行相应包装。

5.Action,其实质为双向事件转发:各客户控件->Action->OnExecute,OnUpdata->Action属性改变->各客户控件。

6.Owner-draw,还是定制控件画出自身?一个两难的选择。从一个OO纯化论者的角度看,Owner-draw实在是对封装的一种破坏。定制控件画出自身,却又未免劳民伤财,浪费资源。

7.TreeView,树状视图。XML不正是擅长树的表达吗?干嘛不给他们结合结合?

    唉,操作性的东西,能想的能写的实在不多,对吧?希望接下来的几章,能激荡起脑力才是。

------------------------------------
   E-mail:Dream_soft@263.net
   HomePage:www.hisee.net
   QQ:80512698

   本文为Dreamer(Dream_soft)原创,版权归Dreamer(Dream_soft)所有,欢迎各网站转载。转载时请保持原文完整并保留版权信息。

一个C++程序员的Delphi学习笔记

                  一个C++程序员的Delphi学习笔记   说心里话,站在一个C++程序员的立场,是有那么一点看不上用Delphi的开发者的。就几周前,我还撰文维护过C++的尊严。...
  • Dream_soft
  • Dream_soft
  • 2001年09月17日 03:21
  • 3167

【转】Delphi程序员如何找到高薪的工作?

我想现在没有什么比做一个软件工程师更能赚钱的了,当然了,明星除外。在美国,一个优秀的软件工程师,就算在一个平凡的岗位上,也能得到年薪50万(美元)以上的待遇。这绝对不是开玩笑,在北美曾有统计表明,一年...
  • q46mu28wem
  • q46mu28wem
  • 2017年05月23日 10:13
  • 383

如何成为一名优秀的C++程序员

C++这门语言从诞生到今天已经经历了将近30个年头。不可否认,它的学习难度都比其它 语言较高。而它的学习难度,主要来自于它的复杂性。现在C++的使用范围比以前已经少了很多,java、C#、python...
  • Heaven_Evil
  • Heaven_Evil
  • 2017年05月25日 14:20
  • 400

一名C++程序员的成长之路

1.不要看到别人的回复第一句话就说:给个代码吧!你应该想想为什么。当你自己想出来再参考别人的提示,你就知道自己和别人思路的差异。   2.初学者请不要看太多太多的书那会误人子弟的,先找本系统...
  • wo17fang
  • wo17fang
  • 2015年06月06日 10:58
  • 1048

程序员修炼之路-一个成长了3年的程序员。

我的编程之路1.面向对象的编程思想。安装完Visual Studio.NET 2003 (或者Visual Studio.NET 2002)后,在“程序”组里有一个Visual Studio组合帮助集...
  • luckjin
  • luckjin
  • 2004年07月10日 15:30
  • 1934

成为一名程序员的四个阶段!!!

 分类:成长篇    通过以下4个阶段的训练, 没有任何编程基础人就可以成为一名普通的程序员。 第一阶段:掌握一种编程语言     学习内容:学习任意一种主流的编程语言。例如C++语言。     学习...
  • lvwenshuai
  • lvwenshuai
  • 2007年10月15日 23:35
  • 624

C++程序员需要了解的知识

1. C++编译器自动为类产生那几个缺省函数?默认构造函数、拷贝构造函数、析构函数、赋值操作符、取地址操作符、const取地址操作符。 2. 使用C++默认的赋值操作符,那些数据成员会发生错误? ...
  • xcw_1987
  • xcw_1987
  • 2017年02月25日 11:01
  • 324

如何成为一个优秀的程序员(宋劲杉)

标签: 程序员编程语言嵌入式行业前景建议 2013-05-30 18:30 1870人阅读 评论(0) 收藏 举报  分类: 职业规划&时间管理&思维方式(2)  ...
  • lin111000713
  • lin111000713
  • 2017年02月09日 09:36
  • 1198

如何成为一个牛逼的C/C++程序员? (仔细阅读)

这个题目的噱头太大,要真的写起来, 足够写一本书了。   本人是过来人, 结合自身的体会和大家交流一下,希望新人能少走弯路。   每个人的情况不一样,我下面的描述可能并不适合每...
  • u010229420
  • u010229420
  • 2016年08月18日 14:34
  • 3361

理解windows消息机制-delphi消息机制学习笔记。

一、什么是消息? 消息是windows对应用程序发送的有关‘发生了某种事件’的通知。例如点击鼠标,调整窗口大小或键盘上按下一个键,都会引起windows发送一条消息到应用程序中去,去通知应用程序...
  • chinajobs
  • chinajobs
  • 2016年06月23日 16:39
  • 479
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:一个C++程序员的Delphi学习笔记(2)
举报原因:
原因补充:

(最多只允许输入30个字)