挂起某个进程中所有线程的方法

//windows核心编程 第5版中的一段代码  
/* 
函数功能:挂起进程中的所有线程 
参数1:进程ID 
参数2:若为TRUE时对进程中的所有线程调用SuspendThread,挂起线程 
      若为FALSE时对进程中的所有线程调用ResumeThread,恢复线程 
*/  
VOID SuspendProcess(DWORD dwProcessID, BOOL fSuspend)  
{  
    HANDLE hSnapshot = CreateToolhelp32Snapshot(  
        TH32CS_SNAPTHREAD, dwProcessID);  

    if (hSnapshot != INVALID_HANDLE_VALUE) 
    {  

        THREADENTRY32 te = {sizeof(te)};  
        BOOL fOk = Thread32First(hSnapshot, &te);  
        for (; fOk; fOk = Thread32Next(hSnapshot, &te))
        {  
            if (te.th32OwnerProcessID == dwProcessID) 
            {  
                HANDLE hThread = OpenThread(THREAD_SUSPEND_RESUME,  
                    FALSE, te.th32ThreadID);  

                if (hThread != NULL) 
                {  
                    if (fSuspend) 
                    {                        
                        SuspendThread(hThread);  
                    }
                    else  
                    {
                        ResumeThread(hThread);  
                    }
                }  
                CloseHandle(hThread);  
            }  
        }  
        CloseHandle(hSnapshot);  
    }  
}  
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值