检测Windows进程使用C#启动和退出事件而不使用WMI

使用WMI的ManagementEventWatcher / EventArrivedEventHandler将导致创建另一个我想避免的线程. WMI也知道它的延迟.
所以我的问题是:如何在没有WMI的情况下使用C#检测 Windows进程创建/终止?有没有办法从非托管代码执行此操作?

解决方法

您可以使用 Event Tracing for Windows(ETW).具体来说,您要查看 kernel event tracerProcess class的子类.

我从来没有使用托管代码,但this blog post看起来很有用.

而且我不知道这是否会在您的流程中创建额外的线程.

总之,您不需要WMI来监视进程事​​件.您可以使用ETW,但我不知道它是否完全符合您的要求.

相关文章

Windows2012R2备用域控搭建 前置操作 域控主域控的主dns:自...
主域控角色迁移和夺取(转载) 转载自:http://yupeizhi.blo...
Windows2012R2 NTP时间同步 Windows2012R2里没有了internet时...
Windows注册表操作基础代码 Windows下对注册表进行操作使用的...
黑客常用WinAPI函数整理之前的博客写了很多关于Windows编程的...
一个简单的Windows Socket可复用框架说起网络编程,无非是建...