大家好,欢迎来到IT知识分享网。
//扫描进程列表,获得进程名为 ConsoleApplication2.exe的进程句柄B,把当前进程A的伪
//
句柄传递给
B
,在
B
进程中关闭它
句柄传递给
B
,在
B
进程中关闭它
#include "stdafx.h"
#include <iostream>
#include <windows.h>
#include <tlhelp32.h>
#include <process.h>
using namespace std;
#pragma warning(disable:4996)
HANDLE Get(wstring tcExeName)
{
HANDLE hTool = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS,
GetCurrentProcessId());
PROCESSENTRY32 pe;
memset(&pe, 0, sizeof(pe));
pe.dwSize = sizeof(pe);
Process32First(hTool, &pe);
while (Process32Next(hTool, &pe)){
if(wcsicmp(pe.szExeFile , tcExeName.c_str()) == 0){
return OpenProcess(PROCESS_ALL_ACCESS, 0, pe.th32ProcessID);
}
}
return NULL;
}
int _tmain()
{
HANDLE hProcess = NULL;
DuplicateHandle(GetCurrentProcess(), GetCurrentProcess(),
Get(L"ConsoleApplication2.exe"), &hProcess, 0, 0, DUPLICATE_SAME_ACCESS);
while(1){//一直运行,等待被关闭
}
return 0;
}
进程B:
#include "stdafx.h"
#include <windows.h>
#include <iostream>
using namespace std;
int _tmain(int argc, _TCHAR* argv[])
{
cout<<"请输入原始句柄"<<endl;
HANDLE hProcess = NULL;
cin>>hProcess;
DWORD dwExitCode = 0;
GetExitCodeProcess(hProcess, &dwExitCode);
TerminateProcess(hProcess, dwExitCode);
return 0;
}
版权声明:本文为博主原创文章,未经博主允许不得转载。
转载于:https://www.cnblogs.com/qq76211822/p/4712041.html
免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://yundeesoft.com/12820.html