在Delphi中以空终止为整数的BYTE数组(BYTE [])等效于什么?

时间:2019-04-15 13:49:05

标签: arrays sockets delphi delphi-10-seattle

我陷入了麻烦,编译器说:

  

不兼容的类型:“ AnsiChar”和“ Integer”

AnsiChar数组的最后一个元素,即整数,它是一个空终止。如何解决?

C ++代码:

static const BYTE  myarray[] = { 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 0 };
SOCKET s;

// Usage example:
if(Send(s, (char *) myarray, sizeof(myarray), 0) <= 0)
      return;

我在Delphi中的尝试:

var
  MyArray: array [0 .. MAX_PATH] of AnsiChar = ( 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 0 );
  S: TSocket;

// Usage example:
send(S, MyArray, Length(MyArray), 0);

2 个答案:

答案 0 :(得分:8)

您可以几乎以您的方式定义它:

var
  MyArray: array[0..MAX_PATH] of AnsiChar = ('A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', #0);

但是随后您在抱怨元素数量时出错,因此您必须添加250个额外的零才能完成它:

// Possible, but not necessary, see below 
var
  MyArray: array[0..MAX_PATH] of AnsiChar = 
    ('A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 
     'I',  #0,  #0,  #0,  #0, ....
                ...
                ...
                ...            #0,  #0,  #0); 

这可以简单得多,

var
  MyArray: array[0..MAX_PATH] of AnsiChar = 'ABCDEFGHI';

此特殊语法应在大多数版本的Delphi中都有效,并且不会出现编译器错误。

对于 send()期间的长度,您必须使用 StrLen(),而不是 Length()

send(S, MyArray, StrLen(MyArray) + 1, 0);

或者,您可以执行以下操作:

var
  Stg: AnsiString;
begin
  Stg := 'ABCDEFGHI';
  // Second parameter is untyped const, so use ^
  send(S, PAnsiChar(Stg)^, Length(Stg) + 1, 0);

FWIW,#0是具有原始值0 的字符。替代方法是:

Chr(0)
#0
^@ (meaning Control+@; ^A = #1 = Chr(1), ^M = #13, etc.)

以上每个含义都相同。

答案 1 :(得分:4)

您可以使用#0将数字0表示为AnsiChar。但是,C ++代码正在将char的值分配给BYTE数组,并且您不能在Delphi中隐式地将AnsiChar分配给Byte,您需要一个类型-演员。

将C ++代码直接转换为Delphi看起来像这样:

const
  myarray[0..9] of Byte = (Ord('A'), Ord('B'), Ord('C'), Ord('D'), Ord('E'), Ord('F'), Ord('G'), Ord('H'), Ord('I'), 0);
  // alternatively:
  // myarray[0..9] of AnsiChar = ('A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', #0);

var
  s: SOCKET;
begin
  ...
  // Usage example:
  if (send(s, myarray, SizeOf(myarray), 0) <= 0) then
    Exit;
  ...
end;