我的应用程序中有一些“流氓”OutputDebugString 调用会打印出“T”,但我不能只找到它。
是否有可能以某种方式在 OutputDebugString -function 上设置断点并查看它是从哪里调用的?
我正在使用德尔福 2009。
我的应用程序中有一些“流氓”OutputDebugString 调用会打印出“T”,但我不能只找到它。
是否有可能以某种方式在 OutputDebugString -function 上设置断点并查看它是从哪里调用的?
我正在使用德尔福 2009。
OutputDebugString
您的项目中有多少次调用?您可以使用“在文件中查找”对话框来查找它们,如果它们不是太多,应该没有问题。
否则,您当然可以使用搜索和替换并将所有内容替换OutputDebugString(
为raise Exception.Create(
.
你也可以写一个函数
procedure OutputDebugString(const Str: string);
begin
raise Exception.Create(Str);
end;
在项目中所有其他单元使用的单元中。如果仅Windows.pas
在uses
列表中声明了这个新单元,则将使用这个新函数而不是 Windows.pas 函数。
是的,您可以在 Windows.pas 中放置断点。首先,在您的项目中,转到项目选项,然后在调试下,选择“使用调试 DCU”。然后您可以转到 Windows.pas 并在第 30769 行放置一个断点:
procedure OutputDebugString; external kernel32 name 'OutputDebugStringW';
完毕。
现在,从您的应用程序对 OutputDebugString 的任何调用都将在断点处中断。您还可以打开记录断点属性以记录调用堆栈。