【问题标题】:Windows: Atomically suspend an entire process? [duplicate]Windows:自动挂起整个进程? [复制]
【发布时间】:2011-08-30 11:25:33
【问题描述】:

使用 Win32 API,只能使用 SuspendThread() 挂起单个线程,但不能在一次调用中挂起完整的进程。
迭代一个进程线程并一次挂起一个线程不是一个好的选择,因为它可能会导致死锁和意外行为。

这应该是可以在内核中使用 DDK 中的函数(我不记得它的名字)实现的。
怎么可能把这个函数暴露给用户模式?

有没有其他方法可以在不进入内核的情况下实现这一点?

SysInternals 进程浏览器有一个暂停进程的选项。它是怎么做到的?

【问题讨论】:

    标签: windows winapi process suspend


    【解决方案1】:

    实际上这正是MiniDumpWriteDump 的作用——它在创建转储之前单独挂起进程中的所有线程(调用线程除外)。

    仅此一项不应导致死锁或意外行为,尽管显然最好从单独的进程中执行此操作。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2011-09-22
      • 1970-01-01
      • 1970-01-01
      • 2011-07-09
      • 1970-01-01
      • 2013-12-14
      • 2011-08-11
      • 1970-01-01
      相关资源
      最近更新 更多