暂停进程

本文介绍了一种在Windows环境下,通过使用CreateToolhelp32Snapshot、Thread32First、Thread32Next等API,遍历指定进程的所有线程,并实现对这些线程的暂停与恢复的方法。该方法涉及对线程进行操作的详细步骤,包括打开线程、暂停或恢复线程及关闭线程句柄等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

暂停/恢复 某个进程的所有线程 :

void suspendProcess(DWORD pid, BOOL bSuspend)
{
    HANDLE snap = CreateToolhelp32Snapshot( TH32CS_SNAPTHREAD, pid );
    if(snap == INVALID_HANDLE_VALUE){
        return;
    }
    THREADENTRY32 th32;
    th32.dwSize = sizeof(THREADENTRY32);
    if(!Thread32First (snap,&th32))
    {
        CloseHandle(snap);
        return;
    }
    do
    {
        if(th32.th32OwnerProcessID == pid)
        {
            HANDLE hTh = OpenThread(THREAD_SUSPEND_RESUME,FALSE,th32.th32ThreadID);
            if(hTh){
                if(bSuspend)
                    SuspendThread(hTh);
                else
                    ResumeThread(hTh);
            }
           CloseHandle(hTh);
        }
    }while(Thread32Next(snap,&th32));
    CloseHandle(snap);
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值