我想创建一个以shorttring数组作为参数的过程 procedure f(const a, b: Array of shortstring); 我想用已知长度和已知长度的短线阵列来称呼它,例如 var A, B: array[1..2] of string[5]; C, D: array[1..40] of strin
procedure f(const a, b: Array of shortstring);
我想用已知长度和已知长度的短线阵列来称呼它,例如
var A, B: array[1..2] of string[5]; C, D: array[1..40] of string[12]; begin f(A,B); f(C,D); end;
这导致编译器错误E2008不兼容的类型.
这是为什么?我可以编写一个可以获取shorttring数组的过程(任何长度的数组/字符串)吗?
为什么要使用短裤?
缺点是现有记录中的字段.这些记录有很多短线串.为了将数据从turbo power B-Tree Filer迁移到SQL数据库,一步是将记录转换为数据集,然后返回记录,以确认所有字段都在两个方向上正确转换.我一直在记录上使用CompareMem来检查这一点,但它没有提供关于转换错误所在的字段的足够信息.因此创建了一个小程序,它从记录定义中生成代码来比较两个记录.对于这个代码生成器,我需要一个函数来比较shorttrings.它最终在短线上使用CompareMem.
在类似的情况下,我使用了以下内容:type
TOpenArrayOfOpenString = record
strict private
FSizeOfString: Integer;
FpStart: PChar;
FArrayLength: Integer;
function GetItemPtr(AIndex: Integer): PShortString;
public
constructor Init(var AFirstString: Openstring; AArrayLength: Integer);
function Equals(const AArray: TOpenArrayOfOpenString): Boolean;
property SizeOfString: Integer read FSizeOfString;
property pStart: PChar read FpStart;
property ArrayLength: Integer read FArrayLength;
property ItemPtrs[AIndex: Integer]: PShortString read GetItemPtr; default;
end;
{ TOpenArrayOfOpenString }
constructor TOpenArrayOfOpenString.Init(var AFirstString: Openstring; AArrayLength: Integer);
begin
FSizeOfString := SizeOf(AFirstString);
FpStart := @AFirstString[0]; // incl. length byte!
FArrayLength := AArrayLength;
end;
function TOpenArrayOfOpenString.Equals(const AArray: TOpenArrayOfOpenString): Boolean;
begin
Result := CompareMem(pStart, AArray.pStart, SizeOfString * ArrayLength);
end;
function TOpenArrayOfOpenString.GetItemPtr(AIndex: Integer): PShortString;
begin
Result := PShortString(pStart + AIndex * SizeOfString);
end;
你可以像这样使用它:
procedure f(const a: TOpenArrayOfOpenString);
var
i: Integer;
begin
for i := 0 to Pred(a.ArrayLength) do
Writeln(a[i]^);
end;
procedure Test;
var
A: array[1..2] of string[5];
C: array[1..40] of string[12];
begin
f(TOpenArrayOfOpenString.Init(A[1], Length(A)));
f(TOpenArrayOfOpenString.Init(C[1], Length(C)));
end;
它不像语言中内置的解决方案那样优雅,而且它有点hacky,因为它依赖于事实/希望/ ……数组中的字符串是连续布局的.但它现在已经有一段时间了.
