为了加快硬件的访问速度, 编译器通常要使用"数据对齐", 譬如:
//下面结构中: SizeOf(TRec) = 6; 因为 b 在这里也要占 2 字节. TRec = record a: Word; b: Byte; c: Word; end;下面是一个测试:
//下面结构中: SizeOf(TRec) = 16; 这里的 a 和 b 共占了 8 个字节. TRec = record a: Byte; b: Byte; c: Double; end;
//下面结构中: SizeOf(TRec) = 8; 这里的 a 和 b 共占了 4 个字节. TRec = record a: Byte; b: Byte; c: Integer; end;
//下例使用了结构压缩(压缩后就对不齐了), 它们的大小会分别是: 2、1、8 字节 TRec = packed record a: Word; b: Byte; c: Double; end;
unit Unit1; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialogs, StdCtrls; type TForm1 = class(TForm) Memo1: TMemo; procedure FormCreate(Sender: TObject); end; var Form1: TForm1; implementation {$R *.dfm} type rec1 = record x: Integer; y: Integer; z: Integer; end; rec2 = record x: Integer; y: Byte; z: Integer; end; rec3 = packed record x: Integer; y: Byte; z: Integer; end; procedure TForm1.FormCreate(Sender: TObject); const DashLine = '----------------------------------'; var r1: rec1; r2: rec2; r3: rec3; begin Memo1.Align := alClient; Memo1.Clear; Memo1.Lines.Add(Format('rec1 结构的大小是: %d', [SizeOf(rec1)])); Memo1.Lines.Add(Format('rec2 结构的大小是: %d', [SizeOf(rec2)])); Memo1.Lines.Add(Format('rec3 结构的大小是: %d', [SizeOf(rec3)])); Memo1.Lines.Add(DashLine); Memo1.Lines.Add(Format('r1 中 x 的地址是: %d', [Integer(@r1.x)])); Memo1.Lines.Add(Format('r1 中 y 的地址是: %d', [Integer(@r1.y)])); Memo1.Lines.Add(Format('r1 中 z 的地址是: %d', [Integer(@r1.z)])); Memo1.Lines.Add(DashLine); Memo1.Lines.Add(Format('r2 中 x 的地址是: %d', [Integer(@r2.x)])); Memo1.Lines.Add(Format('r2 中 y 的地址是: %d', [Integer(@r2.y)])); Memo1.Lines.Add(Format('r2 中 z 的地址是: %d', [Integer(@r2.z)])); Memo1.Lines.Add(DashLine); Memo1.Lines.Add(Format('r3 中 x 的地址是: %d', [Integer(@r3.x)])); Memo1.Lines.Add(Format('r3 中 y 的地址是: %d', [Integer(@r3.y)])); Memo1.Lines.Add(Format('r3 中 z 的地址是: %d', [Integer(@r3.z)])); Memo1.Lines.Add(DashLine); Memo1.Lines.Add('从地址间隔中可见端倪'); end; end.
//测试效果图: