第二十章-开发Delphi对象式数据管理功能(三)(2)

20.2.1.2 TFiler对象的实现原理

TFiler对象是Filer对象的基础类,它定义的大多数方法都是抽象类型的,没有具体实现它,这些方法要在TReader和TWrite中覆盖。但它们提供了Filer对象的框架,了解它无疑是很重要的。

1. TFiler对象属性的实现

TFiler对象定义了三个属性:Root、Ancestor和IgnoreChildren。正如定义对象属性通常所采用的方法那样,要在private部分定义存储属性值的数据域,然后在public或Published部分定义该属性,并按需要增加读写控制。它们的定义如下:

TFiler = class(TObject)

private

FRoot: TComponent;

FAncestor: TPersistent;

FIgnoreChildren: Boolean;

public

property Root: TComponent read FRoot write FRoot;

property Ancestor: TPersistent read FAncestor write FAncestor;

property IgnoreChildren: Boolean read FIgnoreChildren write FIgnoreChildren;

end;

它们在读写控制上都是直接读写私有的数据域。

在介绍TReader和TWriter的实现,我们还会看到这几个属性的原理介绍。

2. TFiler对象方法的实现

在TFiler对象定义的众多方法中很多都是抽象类方法,没有具体实现。在TFiler 的后继对象TReader中覆盖了这些方法。在后面章节,会介绍这些方法的实现。

在TFiler对象中有具体实现的有两个方法Create和Destroy。

⑴ Create方法的实现

Create方法是TFiler的构造方法,它有两个参数Stream和BufSize。Stream是指定与TFiler对象相联系的Stream对象,Filer对象都是用Stream对象完成具体的读写。BufSize是TFiler对象内部开设的缓冲区的大小。Filer对象内部开设缓冲区是为了加快数据的读写,它的实现如下:

constructor TFiler.Create(Stream: TStream; BufSize: Integer);

begin

FStream := Stream;

GetMem(FBuffer, BufSize);

FBufSize := BufSize;

end;

FStream、FBuffer和FBufSize都是TFiler在private部分定义的数据域。FStream表示与Filer对象相联的Stream对象,FBuffer指向Filer对象内部开设的缓冲区,FBufSize是内部缓冲区的大小。Create方法用Stream参数值给FStream赋值,然后用GetMem分配BufSize大小的动态内存作为内部缓冲区。

⑵ Destroy方法的实现

Destroy方法是TFiler对象的析构函数,它的作用就是释放动态内存。

destructor TFiler.Destroy;

begin

if FBuffer <> nil then FreeMem(FBuffer, FBufSize);

end;

20.2.2 TWriter对象

TWriter 对象是可实例化的,往流中写数据的Filer对象。TWriter对象直接从TFiler继承而来,除了覆盖从TFiler继承的方法外,还增加了大量的关于写各种数据类型(如Integer、String和Component等)的方法。TWriter对象和TReader 对象配合使用将使对象读写发挥巨大作用。

时间: 2024-09-02 16:27:57

第二十章-开发Delphi对象式数据管理功能(三)(2)的相关文章

第二十章-开发Delphi对象式数据管理功能(四)(6)

7. SetName方法和OnSetName事件 因为在OnSetName事件中,Name参数是var型的,所以可以用OnSetName事件处理过程修改所读部件的名字.而OnSetName事件处理过程是在SetName方法中实现的. procedure TReader.SetName(Component: TComponent; var Name: string); begin if Assigned(FOnSetName) then FOnSetName(Self, Component, Na

第二十章-开发Delphi对象式数据管理功能(一)-(1)

面向对象技术是九十年代的主流技术,各类应用软件如果以面向对象的方法构造并且渗透面向对象的风格将使软件具有更高的品质.在面向对象程序设计中,对象式数据管理占有很重要的地位.在Delphi中,对对象式数据管理的支持方式是其一大特色. Delphi是一个面向对象的可视化设计与面向对象的语言相结合的集成开发环境.Delphi的核心是部件.部件是对象的一种.Delphi应用程序完全是由部件来构造的,因此开发高性能的Delphi应用程序必然会涉及对象式数据管理技术. 对象式数据管理包括两方面的内容: ● 用

第二十章-开发Delphi对象式数据管理功能(一)-(2)

20.1.1.2 TStream的实现原理 TStream对象是Stream对象的基础类,这是Stream对象的基础.为了能在不同媒介上的存储数据对象,后继的Stream对象主要是在Read和Write方法上做了改进,.因此,了解TStream是掌握Stream对象管理的核心.Borland公司虽然提供了Stream对象的接口说明文档,但对于其实现和应用方法却没有提及,笔者是从Borland Delphi 2.0 Client/Server Suite 提供的源代码和部分例子程序中掌握了流式对象

第二十章-开发Delphi对象式数据管理功能(三)(5)

2. TWriter方法的实现 ⑴ WriteListBegin和WriteListEnd的实现 这两个方法都是用于写连续若干个相同类型的值.WriteListBegin写入VaList标志,WriteListEnd写入VaNull标志. procedure TWriter.WriteListBegin; begin WriteValue(vaList); end; procedure TWriter.WriteListEnd; begin WriteValue(vaNull); end; 这两

第二十章-开发Delphi对象式数据管理功能(三)(4)

20.2.2.2 TWriter对象的实现 TWriter对象提供了许多往流中写各种类型数据的方法,这对于程序员来说是很重要的功能.TWrite对象往流中写数据是依据不同的数据采取不同的格式的. 因此要掌握TWriter对象的实现和应用方法,必须了解Writer对象存储数据的格式. 首先要说明的是,每个Filer对象的流中都包含有Filer对象标签.该标签占四个字节其值为"TPF0".Filer对象为WriteSignature和ReadSignature方法存取该标签.该标签主要用于

第二十章-开发Delphi对象式数据管理功能(三)(3)

20.2.2.1 TWriter对象的属性和方法            1. Position属性      声明:property Position: Longint;       TWriter对象的Position属性表示相关联的流中的当前要写的位置,TReader       对象也有这个属性,但与TReader对象不同的是TWriter对象的Position的值比流的Position值小,这一点一看属性实现就清楚了.      2. RootAncesstor属性      声明:pr

第二十章-开发Delphi对象式数据管理功能(三)(6)

⑶ 部件的写入 TWriter对象中与写入部件有关的方法有WriteSignature.WritePrefix.WriteComponent.WriteDescendant和WriteRootComponent. WriteSignature方法用于往流中写入Filer对象标签. procedure TWriter.WriteSignature; begin Write(FilerSignature, SizeOf(FilerSignature)); end; FilerStgnature是字符

第二十章-开发Delphi对象式数据管理功能(三)(1)

20.2.1.1 TFiler对象的属性和方法 1. Root属性 声明:property Root: TComponent; Root 属性给Filer对象指出被读写的对象中哪一个对象是根或主要拥有者.RootComponent和WriteRootComponent方法在读和写部件及其拥有的部件前先设置Root的值. 2. Ancestor属性 声明:property Ancestor: TPersistent; Ancestor属性用于往继承下来的窗体中写部件,因为当写部件时,Write对象

第二十章-开发Delphi对象式数据管理功能(二)(2)

4. 析构方法Destroy 该方法产生给资源解锁,然后释放该资源,最后调用继承的Destroy方法释放ResourceStream.其实现如下: destructor TResourceStream.Destroy; begin UnlockResource(HGlobal); FreeResource(HResInfo); inherited Destroy; end; 回顾Initialize方法,我们不难发现: ● ResourceStream没有额外地给资源重新分配内存,而是直接使用H