假如不是第一次初始化的话。因此,有必要对多段数据流的整合操作做一些有利的约束。如增加INSERT(插入)、 APPEND(追加)之类的方法。从TStream的定义及其派生子类我们得知,CopyFrom是唯一可以加以利用的公用函数,它从指定的流上拷贝指定数量的字节后返回一长整型值,该值代表最后成功传送的实际字节数。其后,我们用Seek函数来避免数据流之间的相互覆盖,并以此来界定后来者加入的位置。在SEEK函数的定义中,第一个参数为偏移量,第二个参数是个定位标识,其定义如下:
soFromBeginning表示在流的顶头开始位移,第一个参数必须 $#@62;=0.
soFromCurrent表示从当前位置开始位移。
soFromEnd表示从流的最后开始位移,第一个参数必须$#@60;= 0.
SEEK操作成功后,由Position属性存放流当前的位置值。Size属性是该流到目前为止的长度。
具体操作见以下范例:
unit DemoUnit;
...
type
TForm1 = class(TForm)
...
Memo1: TMemo;
procedure FormCreate(Sender: TObject);
procedure Button1Click(Sender: TObject);
procedure FormDestroy(Sender: TObject);
procedure Button2Click(Sender: TObject);
procedure Button3Click(Sender: TObject);
private
{ Private declarations }
// 建立一个演示内存流
STO : TMemoryStream;
public
{ Public declarations }
end;
var
Form1: TForm1;
implementation
{$R *.DFM}
procedure TForm1.FormCreate(Sender: TObject);
begin
...
Try
//创建内存流的对象
STO := TMemoryStream.Create;
Finally
...
end;
...
end;
procedure TForm1.Button1Click(Sender: TObject);
begin
...
//初始化内存流对象,并移动指针到头部
STO.LoadFromFile( OpenDialog1.FileName );
STO.Seek( 0, soFromBeginning );
//把调入的东西显示出来
Memo1.Lines.LoadFromStream( STO );
...
end;
//以下的工作必须在内存流初始化后方能进行
//插入演示
procedure TForm1.Button2Click(Sender: TObject);
Var
SWA : TMemoryStream; //定义一个临时内存流
begin
...
//创建临时工作的对象
SWA := TMemoryStream.Create;
//加载要插入的目标
SWA.LoadFromFile( OpenDialog1.FileName );
//移动演示流的指针到头部,预备交换
STO.Seek( 0, soFromBeginning );
//移动临时流的指针到尾部,接收演示流
SWA.Seek( 0, soFromEnd );
SWA.CopyFrom( STO, STO.Size );
//把演示流换成新的内容
STO.LoadFromStream( SWA );
STO.Seek( 0, soFromBeginning );
//把插入后的内容显示出来
Memo1.Lines.LoadFromStream( STO );
...
end;
//追加演示
procedure TForm1.Button3Click(Sender: TObject);
Var
SWA : TMemoryStream;//定义一个临时内存流
begin
...
//创建临时工作的对象并加载要追加的目标
SWA := TMemoryStream.Create;
SWA.LoadFromFile( OpenDialog1.FileName );
//移动演示流的指针到尾部,接收临时流
STO.Seek( 0, soFromEnd );
SWA.Seek( 0, soFromBeginning );
//拷贝,移动指针后显示
STO.CopyFrom( SWA, SWA.Size );
STO.Seek( 0, soFromBeginning );
Memo1.Lines.LoadFromStream( STO );
...
end;
....
在Insert过程当中,仅仅只是把新来的流加到最前面,而没有考虑在任何位置的插入问题,假如要对任何条件都满足的话,就要考虑一个复杂的前提:流的分解。由于篇幅有限,本文不再叙述,有爱好的朋友可试一试。
right"(出处:清风软件下载学院)