加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

delphi – TStream.WriteData和TStream.ReadData的Count参数的目

发布时间:2020-12-15 09:12:51 所属栏目:大数据 来源:网络整理
导读:TStream类包含许多WriteData重载,具有以下形式: function WriteData(const Buffer: Int32; Count: Longint): Longint; overload; 所有常见的嫌疑人,AnsiChar,Char,UInt32,Double等都有重载.同样适用于ReadData.我试图了解Count参数的用途.上述过载的实现如
TStream类包含许多WriteData重载,具有以下形式:

function WriteData(const Buffer: Int32; Count: Longint): Longint; overload;

所有常见的嫌疑人,AnsiChar,Char,UInt32,Double等都有重载.同样适用于ReadData.我试图了解Count参数的用途.上述过载的实现如下:

function TStream.Skip(Amount: Integer): Integer;
var
  P: Integer;
begin
  P := Position;
  Result := Seek(Amount,soCurrent) - P;
end;

function TStream.WriteData(const Buffer: Int32; Count: Longint): Longint;
const
  BufSize = SizeOf(Buffer);
begin
  if Count > BufSize then
    Result := Write(Buffer,BufSize) + Skip(Count - BufSize)
  else
    Result := Write(Buffer,Count)
end;

我可以清楚地看到这段代码的作用,但我无法理解为什么执行部分写入会有意义.为什么用Count<来调用这个函数是有意义的? BUFSIZE?那时的行为很奇怪. 有谁知道为什么要添加这些重载以及它们的目的是什么?我自然而然地看过documentation这些方法无话可说.

另外,我将提交有关此行的错误报告:

Result := Write(Buffer,BufSize) + Skip(Count - BufSize);

假设对Write的调用将在调用Skip之前发生,这是错误的.未定义运算符对运算符的评估顺序.这段代码应该像这样编写:

Result := Write(Buffer,BufSize);
inc(Result,Skip(Count - BufSize));

解决方法

理论制作

如果TStream早于引入了重载关键字(Delphi 3 IIRC),他们可能会引入一种方法来编写可能是int32的整数.当使用“byte”变量调用函数时,它将作为Integer传递给函数,然后Count参数只允许写入一个字节.现在他们支持这个以实现向后兼容.

在某些情况下(如下一个),支持Count< Bufsize确实特别愚蠢:

function WriteData(const Buffer: Int8; Count: Longint): Longint; overload;

另一个理由是在下一种情况下,变量只需要保存为流作为Int8,但在程序执行期间作为Int32处理(因为它传递给只接受var:Int32作为参数的函数).

procedure SomeProc(var MyInt : Integer);

procedure DoSomeStream;
var
  iVal : Integer;
//  bVal : ShortInt;
begin
  SomeProc(iVal);
  Stream.WriteData(iVal,SizeOf(Byte));
  //Instead of
//  SomeProc(iVal);
//  bVal := iVal;
//  Stream.WriteData(bVal)
end;

我不是说它是必需的(可以解决),但在某些情况下,它可能是有用的.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读