苛评VCL: 混乱的TStream

为什么这么苛刻地来评论VCL的基础类设计,我已经在前一篇关于TObject的文章中讲过。今天我拿出在一次跟踪VCL代码的过程中发现的问题。在此之前,我没有任何理由会相信会存在这样的情况。

TForm读取dfm文件创建窗体过程大家一定都比较清楚,其中负责读取的是Classes.pas单元中的TReader类,而它在实现的时候,会调用到如下的函数:

  
  
  
  
  1. function InternalReadComponentRes(const ResName: string; HInst: THandle; var Instance: TComponent): Boolean;  
  2. var  
  3.   HRsrc=\'#\'"  
  4. begin                   { avoid possible EResNotFound exception }  
  5.   if HInst = 0 then HInst := HInstance;  
  6.   HRsrc := FindResource(HInst, PChar(ResName), RT_RCDATA);  
  7.   Result := HRsrc <> 0;  
  8.   if not Result then Exit;  
  9.   with TResourceStream.Create(HInst, ResName, RT_RCDATA) do  
  10.   try  
  11.     Instance := ReadComponent(Instance);  
  12.   finally  
  13.     Free;  
  14.   end;  
  15.   Result := True;  
  16. end

大家请注意TResourceStream的方法ReadComponent。是的,我想说的其实就是这个方法。大家可以回过头来看看TStream的声明:

  
  
  
  
  1. ...  
  2. function ReadComponent(Instance: TComponent): TComponent;  
  3. function ReadComponentRes(Instance: TComponent): TComponent;  
  4. procedure WriteComponent(Instance: TComponent);  
  5. procedure WriteComponentRes(const ResName: string; Instance: TComponent);  
  6. procedure WriteDescendent(Instance, Ancestor: TComponent);  
  7. procedure WriteDescendentRes(const ResName: string; Instance, Ancestor: TComponent);  
  8. procedure WriteResourceHeader(const ResName: string; out FixupInfo: Integer);  
  9. procedure FixupResourceHeader(FixupInfo: Integer);  
  10. procedure ReadResHeader;  
  11. ... 

对于Stream这个抽象概念,很多人对它的理解过程都是曲折的。但不管怎么样,它基本特性还是比较清晰的。Read、Write、Position、Seek等等基本方法,构成了流的基本属性。

然而,令我不明白的地方是,为什么Delphi会在基础类TStream中增加上述的那些有关Component的方法。这些显然和流的职责没有关系!

在单一职责原则中,建议将两种不同的职责分成两个类实现,或继承、或组合。要说TStream的这些Component的方法,要么可以定义单独的Component资源类, 要么做出TStream的Helper类。但总比像VCL这样设计好吧。

现在猜想VCL当时的设计情形,很可能Classes单元的类,很多是为了Delphi的组件系统的实现(或者说是IDE本身)。所以很多类在设计的时候,默认都引入了TComonent类。

这么说是有根据的,不光是TStream类,在这个单元中的TParser类也是如此。我发现TParser类的时候是非常惊喜的,但是使用后发现,其规则是按照dfm来做的。在分析Delphi的源码的时候,会遇到注释不能识别的问题。

一向认为单一职责最难把握,现在看VCL,呵呵,确实如此啊。

你可能感兴趣的:(职场,休闲,混乱,苛评VCL,TStream)