使用Delphi的数据类型错位?

时间:2014-03-04 02:12:05

标签: delphi memory logging

添加以下Delphi函数后,我收到有关数据类型错位的错误:Project ... faulted with message: 'datatype misalignment at 0x77a7d7d8'. Process Stopped. Use Step or Run to continue.

我添加的功能如下。请注意,该函数实际上已成功完成,但实际上只将时间戳写入文件。

procedure Log(msg : String);
var
  tempFolderChars : array [0..MAX_PATH] of Char;
  tempFolder : string;
  logFile : TextFile;
  dt : TDateTime;
begin
  GetTempPath(SizeOf(tempFolderChars), tempFolderChars);
  tempFolder := IncludeTrailingPathDelimiter(String(tempFolderChars));
  dt := Now();

  AssignFile(logFile, tempFolder + 'GenericHolding.txt');
  if FileExists(tempFolder + 'GenericHolding.txt') then
    Append(logFile)
  else
    ReWrite(logFile);

  Write(logFile, FormatDateTime('yyyy-mm-dd hh:nn:ss ', now));
  Write(logFile, msg);
  Write(logFile, #13, #10);
  CloseFile(logFile);
end;

编辑:添加了更多的装配输出。

ntdll.NtQueryInformationProcess:
77BAFAC8 B816000000       mov eax,$00000016
77BAFACD 33C9             xor ecx,ecx
77BAFACF 8D542404         lea edx,[esp+$04]
77BAFAD3 64FF15C0000000   call dword ptr fs:[$000000c0]
77BAFADA 83C404           add esp,$04
77BAFADD C21400           ret $0014

1 个答案:

答案 0 :(得分:5)

在Delphi 2007和更早版本中,

CharAnsiCharSizeOf(Char)=1),但在Delphi 2009及更高版本中是WideCharSizeOf(Char)=2)。

GetTempPath()期望第一个参数指定缓冲区可以容纳的字符数,但是您要指定字节数

在Delphi 2007及更早版本中,SizeOf(tempFolderChars)Length(tempFolderChars)将是相同的值,但在Delphi 2009及更高版本中它们将不相同。在后一种情况下,你告诉GetTempPath()你可以接受两倍于你真实的字符。

您需要将SizeOf(tempFolderChars)更改为Length(tempFolderChars)。您还需要注意GetTempPath()的返回值,因为它会告诉您实际将多少字符写入缓冲区。

请改为尝试:

procedure Log(msg : String);
var
  tempFolderChars : array [0..MAX_PATH] of Char;
  tempFolder : string;
  len: DWORD;
  ...
begin
  len := GetTempPath(Length(tempFolderChars), tempFolderChars);
  if len = 0 then Exit;
  SetString(tempFolder, tempFolderChars, len);
  tempFolder := IncludeTrailingPathDelimiter(tempFolder);
  ...
end;