VC 通过进程名 杀掉进程 (KillProcessFromName注释版)

//kill进程from名字  
BOOL KillProcessFromName(CString strProcessName)  
{  
    //创建进程快照(TH32CS_SNAPPROCESS表示创建所有进程的快照)  
    HANDLE hSnapShot = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS,0);  
  
    //PROCESSENTRY32进程快照的结构体  
    PROCESSENTRY32 pe;  
  
    //实例化后使用Process32First获取第一个快照的进程前必做的初始化操作  
    pe.dwSize = sizeof(PROCESSENTRY32);  
  
  
    //下面的IF效果同:  
    //if(hProcessSnap == INVALID_HANDLE_VALUE)   无效的句柄  
    if(!Process32First(hSnapShot,&pe))  
    {  
        return FALSE;  
    }  
  
    //将字符串转换为小写  
    strProcessName.MakeLower();  
  
    //如果句柄有效  则一直获取下一个句柄循环下去  
    while (Process32Next(hSnapShot,&pe))  
    {  
  
        //pe.szExeFile获取当前进程的可执行文件名称  
        CString scTmp = pe.szExeFile;  
  
  
        //将可执行文件名称所有英文字母修改为小写  
        scTmp.MakeLower();  
  
        //比较当前进程的可执行文件名称和传递进来的文件名称是否相同  
        //相同的话Compare返回0  
        if(!scTmp.Compare(strProcessName))  
        {  
  
            //从快照进程中获取该进程的PID(即任务管理器中的PID)  
            DWORD dwProcessID = pe.th32ProcessID;  
            HANDLE hProcess = ::OpenProcess(PROCESS_TERMINATE,FALSE,dwProcessID);  
            ::TerminateProcess(hProcess,0);  
            CloseHandle(hProcess);  
            return TRUE;  
        }  
        scTmp.ReleaseBuffer();  
    }  
    strProcessName.ReleaseBuffer();  
    return FALSE;  
}  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值