字节数组与String类型的转换

还是本着上篇文章的原则,只不过在Delphi中string有点特殊!

先了解一下Delphi中的string

 

1.

string = AnsiString = 长字符串,理论上长度不受限制,但其实受限于最大寻址范围2的32次方=4G字节,变量Str名字是一个指针,指向位于堆内存的字符序列,字符序列起始于@Str[1],@Str[1]偏移负16个字节的空间存储着字串长度、引用计数等信息。字符序列以NULL结束。
2.
string[n] = ShortString = 短字符串,最多容纳255个字符,实际长度是字符长度+1,是Delphi的简单类型,Str[0]存储着字符的个数,第一个字符从Str[1]开始存放,不以NULL结束。

 

所以只要理解这一理论,转string应该就不成问题!

//拿昨天一贴为例:需要将buf[50]-buf[81]的数组转为string[32]

一、字节数组转string

1.

var

  buf: array[0..100] of byte;

  str: string[32];//仅仅开辟了一个32个空间的内存,由于第1位没有用setlength初始化,导致长度不定

  i  : Integer;

begin

 //如果在此处就对str进行赋值,str[0]位就有计数了,如果在使用之前没有对其进行使用,用SetLength进行赋值

  for i := 50 to 81 do buf[i] := ord('A') + i -50;//测试数据

  SetLength(str, 32);//设置str[0]=32;

  Move(buf[50], str[1], 32);//内存复制

  ShowMessage (str);

end;

在这里重新认识一下SetLength,SetLength有2个功能,1.对Short string类型进行设置长度(专门针对其第1位进行设置)2.对动态数组进行设置



2.

如果想把buf内容赋给string(string与string[]不一样,string是一个动态数组,还没有分配空间,而string[]已经预分配了空间,只不过str[0]处没赋初值,这时如果用Move的话会把Byte数组中的数据拷贝到string空间中,而string这时还没有分配内存,肯定会造成AV错误)

var

  buf: array[0..100] of byte;

  str: string;

  i  : Integer;

begin

  for i := 50 to 81 do buf[i] := ord('A') + i -50;

  SetLength(str, 32);

  Move(buf[50], str[1], 32);//注意,这里是从str[1]开始复制的

  ShowMessage (str);

end;



二、string转为字节数组

var

  buf: array[0..100] of byte;

  str: string;



begin

  str:='abcdefg';

  Move( str[1],buf[0], 32);//注意,这里是从str[1]开始复制的

  ShowMessageFmt('$%.2d, $%.2d, $%.2d, $%.2d', [buf[3], buf[2], buf[1], buf[0]]);



end;
View Code

 字节数组与结构体的转换 还是一个原则,在此不再详述!

 

type

  PData=^TData;

  TData = packed record

    a: Integer;

    b: Word;

  end;

var

  bs: array[0..5] of Byte;  

  data: PData;

begin

  FillChar(bs, Length(bs), 0);

  bs[0] := $10;

  bs[1] := $27;



  data := @bs[0];//把字节数组的首址传给结构体

  ShowMessage(IntToStr(data^.a)); //系统帮我们捆绑读取



end;
View Code

 

你可能感兴趣的:(String类)