/****************************************************
枚举系统所有进程,输出进程ID、进程名称、进程全路径
http://blog.youkuaiyun.com/midle110/article/details/8026618
问题1:当wchar字符的输出时,使用printf("%ls",),使用printf("%s")会出错。
wchar:[a] [\0] printf("%ls",)
char:[a] printf("%s")打印时遇到\0结束,遇到wchar时就会只输出一个字节
*******************************************************/
#include<stdio.h>
#include<wchar.h>
#include<locale.h>
#include<windows.h>
#include<TLHELP32.H>// 声明快照函数的头文件
#include<tchar.h>
#include<conio.h>
#include<stddef.h>
void ShowProcess()
{
PROCESSENTRY32 pe32;//用来存放快照进程信息的一个结构体。(存放一个进程信息和调用成员输出进程信息)
//用来 Process32First指向第一个进程信息,
//并将进程信息抽取到PROCESSENTRY32中。用Process32Next指向下一条进程信息。
pe32.dwSize = sizeof(pe32); //这个操作必须要不然获取不到pe32
// 给系统内的所有进程拍一个快照
HANDLE hprocesssnap = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS , 0);
if ( hprocesssnap == INVALID_HANDLE_VALUE )
{
printf("1\n");
}
BOOL bmore = Process32First(hprocesssnap , &pe32);
HANDLE hfilename = NULL ;
MODULEENTRY32 pes; //这个结构描述了一个条目从一个列表,列举了一个指定的进程所使用的模块。
pes.dwSize = sizeof(MODULEENTRY32);
// 遍历进程快照,轮流显示每个进程的信息
while (bmore)
{
printf("进程名称: %ls \n",pe32.szExeFile);
printf("进程ID: %u \n" , pe32.th32ProcessID );
printf("线程数目: %d \n",pe32.cntThreads);
hfilename = CreateToolhelp32Snapshot(TH32CS_SNAPMODULE , pe32.th32ProcessID );
if (hfilename == NULL )
{
printf("文件名字访问失败!");
}
BOOL i = Module32First(hfilename , &pes);
printf("文件路径: %ls \n" , pes.szExePath);
printf("\n");
bmore = Process32Next(hprocesssnap , &pe32);
}
printf("\n========================The End==========================\n");
getchar();
//关闭内核对象
CloseHandle(hfilename);
CloseHandle(hprocesssnap);
}
int killProcess(WCHAR* ProcessName)
{
int flag;
HANDLE hSnapShot = ::CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);
if (hSnapShot == 0)
return 0;
PROCESSENTRY32 thePE;
thePE.dwSize = sizeof(PROCESSENTRY32);
bool Status = Process32First(hSnapShot, &thePE);//正在运行的第一个系统进程
bool bHaveFlag = false;
DWORD ProcessID = 0;
while (Status)//遍历
{
//遍历正在运行的下一个系统进程
Status = Process32Next(hSnapShot, &thePE);
if (0== wcscmp(thePE.szExeFile,ProcessName))//找到相应的进程 **.exe
{
bHaveFlag = true;
ProcessID = thePE.th32ProcessID;//获取结束进程的 ProcessID
if (!TerminateProcess(OpenProcess(PROCESS_TERMINATE || PROCESS_QUERY_INFORMATION, false, ProcessID), 0))
{
//MessageBox(NULL, L"无法终止指定的进程!", NULL, NULL);
return 1;
}
return 2;//可以终止
}
}
CloseHandle(hSnapShot);
return 3;
}
int main(int argc, char* argv[])
{
setlocale(LC_ALL, "chs");
while(1)
{
int flag;
system("cls");
//ShowProcess();//显示所有进程
//printf("输入要关闭的进程\n");
//getchar();
//wchar_t ws[50];//宽字符数组。
//wscanf(L"%ls", ws);//输入值。
WCHAR ws[] = L"QQ.exe";
flag = killProcess(ws);
if( flag==1)
MessageBox(NULL, L"进程无法结束!", NULL, NULL);
else if(flag == 2)
MessageBox(NULL, L"进程结束!", NULL, NULL);
else if(flag == 3)
MessageBox(NULL, L"尚无该进程!", NULL, NULL);
}
return 0;
}
枚举系统所有进程,输出进程ID、进程名称、进程全路径
http://blog.youkuaiyun.com/midle110/article/details/8026618
问题1:当wchar字符的输出时,使用printf("%ls",),使用printf("%s")会出错。
wchar:[a] [\0] printf("%ls",)
char:[a] printf("%s")打印时遇到\0结束,遇到wchar时就会只输出一个字节
*******************************************************/
#include<stdio.h>
#include<wchar.h>
#include<locale.h>
#include<windows.h>
#include<TLHELP32.H>// 声明快照函数的头文件
#include<tchar.h>
#include<conio.h>
#include<stddef.h>
void ShowProcess()
{
PROCESSENTRY32 pe32;//用来存放快照进程信息的一个结构体。(存放一个进程信息和调用成员输出进程信息)
//用来 Process32First指向第一个进程信息,
//并将进程信息抽取到PROCESSENTRY32中。用Process32Next指向下一条进程信息。
pe32.dwSize = sizeof(pe32); //这个操作必须要不然获取不到pe32
// 给系统内的所有进程拍一个快照
HANDLE hprocesssnap = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS , 0);
if ( hprocesssnap == INVALID_HANDLE_VALUE )
{
printf("1\n");
}
BOOL bmore = Process32First(hprocesssnap , &pe32);
HANDLE hfilename = NULL ;
MODULEENTRY32 pes; //这个结构描述了一个条目从一个列表,列举了一个指定的进程所使用的模块。
pes.dwSize = sizeof(MODULEENTRY32);
// 遍历进程快照,轮流显示每个进程的信息
while (bmore)
{
printf("进程名称: %ls \n",pe32.szExeFile);
printf("进程ID: %u \n" , pe32.th32ProcessID );
printf("线程数目: %d \n",pe32.cntThreads);
hfilename = CreateToolhelp32Snapshot(TH32CS_SNAPMODULE , pe32.th32ProcessID );
if (hfilename == NULL )
{
printf("文件名字访问失败!");
}
BOOL i = Module32First(hfilename , &pes);
printf("文件路径: %ls \n" , pes.szExePath);
printf("\n");
bmore = Process32Next(hprocesssnap , &pe32);
}
printf("\n========================The End==========================\n");
getchar();
//关闭内核对象
CloseHandle(hfilename);
CloseHandle(hprocesssnap);
}
int killProcess(WCHAR* ProcessName)
{
int flag;
HANDLE hSnapShot = ::CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);
if (hSnapShot == 0)
return 0;
PROCESSENTRY32 thePE;
thePE.dwSize = sizeof(PROCESSENTRY32);
bool Status = Process32First(hSnapShot, &thePE);//正在运行的第一个系统进程
bool bHaveFlag = false;
DWORD ProcessID = 0;
while (Status)//遍历
{
//遍历正在运行的下一个系统进程
Status = Process32Next(hSnapShot, &thePE);
if (0== wcscmp(thePE.szExeFile,ProcessName))//找到相应的进程 **.exe
{
bHaveFlag = true;
ProcessID = thePE.th32ProcessID;//获取结束进程的 ProcessID
if (!TerminateProcess(OpenProcess(PROCESS_TERMINATE || PROCESS_QUERY_INFORMATION, false, ProcessID), 0))
{
//MessageBox(NULL, L"无法终止指定的进程!", NULL, NULL);
return 1;
}
return 2;//可以终止
}
}
CloseHandle(hSnapShot);
return 3;
}
int main(int argc, char* argv[])
{
setlocale(LC_ALL, "chs");
while(1)
{
int flag;
system("cls");
//ShowProcess();//显示所有进程
//printf("输入要关闭的进程\n");
//getchar();
//wchar_t ws[50];//宽字符数组。
//wscanf(L"%ls", ws);//输入值。
WCHAR ws[] = L"QQ.exe";
flag = killProcess(ws);
if( flag==1)
MessageBox(NULL, L"进程无法结束!", NULL, NULL);
else if(flag == 2)
MessageBox(NULL, L"进程结束!", NULL, NULL);
else if(flag == 3)
MessageBox(NULL, L"尚无该进程!", NULL, NULL);
}
return 0;
}