3

我在 AQTime 中使用性能分析器。尝试在 IDE 下运行它(使用 Embarcadero RAD Studio XE)。检查项目在此类代码上崩溃:

// Setting a Thread Name (Unmanaged):
// http://msdn.microsoft.com/en-us/library/xcb2z8hs(VS.71).aspx
procedure _NameThreadForDebugging(const ATID: Cardinal; const AThreadName: String);
type
  TThreadNameInfo = record
    FType: LongWord;     // must be 0x1000
    FName: PAnsiChar;    // pointer to name (in user address space)
    FThreadID: LongWord; // thread ID (-1 indicates caller thread)
    FFlags: LongWord;    // reserved for future use, must be zero
  end;
var
  ThreadNameInfo: TThreadNameInfo;
  ThreadName: AnsiString;
begin
  // Applicable only for debugged applications
  if IsDebuggerPresent then
  begin
    FillChar(ThreadNameInfo, SizeOf(ThreadNameInfo), 0);

    ThreadName := AnsiString(AThreadName);
    ThreadNameInfo.FType := $1000;
    ThreadNameInfo.FName := PAnsiChar(ThreadName);
    ThreadNameInfo.FThreadID := ATID;

    try
      RaiseException(cSetThreadNameExcep, 0, SizeOf(ThreadNameInfo) div SizeOf(LongWord), @ThreadNameInfo);
    except
    end;
    Finalize(ThreadName);
  end;
end;

在 IDE 之外运行(在这种情况下,例程将退出而不做任何事情)或在通常的 IDE 调试器下运行(在这种情况下,例程将引发异常,这将由 IDE 的调试器处理)时,它工作正常。

但是,当在 AQTime 下运行时 - 例程将在调用 kernel32.RaiseException 例程时崩溃(内核 32 内某处的 APPCRASH C00001A5)。我已经通过在这个调用周围放置 MessageBoxes(try/except 块)来确认这一点。

显然,在 AQTime 下运行时 IsDebuggerPresent 为 True,但未正确处理异常。

问题:如何检测和避免这种情况?如何检查代码是否在 AQTime 下执行?

AQTime 是 8.22。

4

1 回答 1

6

您可以检查默认传递给分析进程的以下环境变量AQTIME_DEBUGGER_PRESENTAQTIME_SESSION_IDAQTIME_VERSION

注意:确切的变量似乎取决于使用的分析器(或 AQTime 版本?) - 仅在我的情况下AQTIME_SESSION_ID并且AQTIME_VERSION存在。

于 2015-05-22T12:41:37.787 回答