我试图在一个进程中将ClrMD附加到它自己:
private static void Main()
{
var pid = Process.GetCurrentProcess().Id;
WriteLine($"PID: {pid}");
using (var dataTarget = DataTarget.AttachToProcess(pid, 1000))
{
WriteLine($"ClrMD attached");
}
}
但是,我得到了以下例外:
PID: 7416
Unhandled Exception: Microsoft.Diagnostics.Runtime.ClrDiagnosticsException: Could not attach to pid 1CF8, HRESULT: 0x80070057
at Microsoft.Diagnostics.Runtime.DbgEngDataReader..ctor(Int32 pid, AttachFlag flags, UInt32 msecTimeout)
at Microsoft.Diagnostics.Runtime.DataTarget.AttachToProcess(Int32 pid, UInt32 msecTimeout, AttachFlag attachFlag)
at Microsoft.Diagnostics.Runtime.DataTarget.AttachToProcess(Int32 pid, UInt32 msecTimeout)
at BanksySan.Scratch.Console.Program.Main(String[] args)
I可以在被动模式下附着,但不能在无创或无创模式下附着.
发布于 2019-09-04 14:37:46
您可以使用DataTarget.CreateSnapshotAndAttach
。此方法创建流程的快照并从中创建DataTarget
。示例:
var processId = Process.GetCurrentProcess().Id;
using (var dataTarget = DataTarget.CreateSnapshotAndAttach(processId))
{
}
发布于 2018-02-27 13:40:18
Invasive
标志允许该API的使用者通过正常的IDebug函数调用来控制目标进程。该进程将被暂停(在附加期间),以便获取数据并控制目标进程。
在NonInvasive
调试器附加中,进程将被暂停(在附加期间),并且能够获得数据,但调用方无法控制目标进程。当已经有一个调试器附加到进程时,这是非常有用的。
执行Passive
附加意味着没有任何调试器实际附加到目标进程。进程不会暂停,因此对于快速更改数据(例如GC堆或回调堆栈的内容)的查询将非常不一致,除非用户通过其他方法暂停该进程。当使用ICorDebug (托管调试器)附加时,它很有用,因为您不能在ICorDebug中使用非侵入性附加。
https://stackoverflow.com/questions/47621896
复制相似问题