当前位置: 首页 > news >正文

7.5 通过API判断进程状态

进程状态的判断包括验证进程是否存在,实现方法是通过枚举系统内的所有进程信息,并将该进程名通过CharLowerBuff转换为小写,当转换为小写模式后则就可以通过使用strcmp函数对比,如果发现继承存在则返回该进程的PID信息,否则返回-1。

int GetProcessStatus(const char *procressName)
{char pName[MAX_PATH];strcpy(pName, procressName);                           // 拷贝数组CharLowerBuff(pName, MAX_PATH);                        // 将名称转换为小写PROCESSENTRY32 currentProcess;                                    // 存放快照进程信息的一个结构体currentProcess.dwSize = sizeof(currentProcess);                   // 在使用这个结构之前,先设置它的大小HANDLE hProcess = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0); // 给系统内的所有进程拍一个快照if (INVALID_HANDLE_VALUE != hProcess){BOOL bMore = Process32First(hProcess, &currentProcess);while (bMore){CharLowerBuff(currentProcess.szExeFile, MAX_PATH);        // 将进程名转换为小写if (strcmp(currentProcess.szExeFile, pName) == 0)         // 比较是否存在此进程{CloseHandle(hProcess);return currentProcess.th32ProcessID;}bMore = Process32Next(hProcess, &currentProcess);}CloseHandle(hProcess);}return -1;
}

有时候我们需要判断自身进程是否被重复运行了,这种需求在软件开发中经常会遇到,通常该需求可以使用CreateMutex创建或打开一个互斥量对象(Mutex Object),在多线程/进程的环境下,互斥量可用于控制对某个共享资源的访问。其函数声明如下:

HANDLE CreateMutex(LPSECURITY_ATTRIBUTES lpMutexAttributes,BOOL                  bInitialOwner,LPCTSTR               lpName
);

其中,lpMutexAttributes 是用于指定新创建的互斥量的安全描述符的指针;bInitialOwner 表示一个布尔值,指定初始所有权标记,为 TRUE 表示调用线程将拥有该互斥量,否则表示它不属于调用线程;lpName 是可选的,用于命名互斥体,以使得其他线程或者进程可以通过这个名字来打开该互斥量对象。

CreateMutex 函数会返回一个内核对象句柄,用于在之后对该互斥体进行引用和操作,通过使用互斥体可以很容易的实现对进程运行状态的判断。

#include <Windows.h>
#include <stdio.h>// 判断是否重复运行
BOOL IsAlreadyRun()
{HANDLE hMutex = NULL;hMutex = CreateMutex(NULL, FALSE, "RUN");if (hMutex){if (ERROR_ALREADY_EXISTS == GetLastError())return TRUE;}return FALSE;
}int main(int argc, const char * argv[])
{if (IsAlreadyRun() == TRUE)printf("重复运行 \n");elseprintf("没有重复运行 \n");system("pause");return 0;
}

对进程位数的判断也是有必要的,通常在Windows系统下进程位数的有多种方法实现,第一种方式GetNativeSystemInfo调用该函数并判断函数内的特定成员,即可得到当前系统是否为64位,当然通过使用Is64BitPorcess函数也可实现对特定进程的判断,此方式实现原理是通过调用IsWow64Process函数实现;

#include <stdio.h>
#include <Windows.h>
#include <tlhelp32.h>// 判断自身系统是否为64位
BOOL IsSelf64bitSystem()
{SYSTEM_INFO si;GetNativeSystemInfo(&si);if (si.wProcessorArchitecture == PROCESSOR_ARCHITECTURE_AMD64 ||si.wProcessorArchitecture == PROCESSOR_ARCHITECTURE_IA64)return TRUE;elsereturn FALSE;
}// 判断指定进程是否为64位进程
BOOL Is64BitPorcess(DWORD dwProcessID)
{HANDLE hProcess = OpenProcess(PROCESS_QUERY_INFORMATION, FALSE, dwProcessID);if (hProcess){typedef BOOL(WINAPI *LPFN_ISWOW64PROCESS) (HANDLE, PBOOL);LPFN_ISWOW64PROCESS fnIsWow64Process = (LPFN_ISWOW64PROCESS)GetProcAddress(GetModuleHandleW(L"kernel32"), "IsWow64Process");if (NULL != fnIsWow64Process){BOOL bIsWow64 = FALSE;fnIsWow64Process(hProcess, &bIsWow64);CloseHandle(hProcess);if (bIsWow64)return FALSE;elsereturn TRUE;}}return FALSE;
}int main(int argc, char *argv[])
{PROCESSENTRY32 pe32;pe32.dwSize = sizeof(pe32);HANDLE hProcessSnap = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);BOOL bMore = Process32First(hProcessSnap, &pe32);while (bMore){printf("进程PID: %5d 是否64位: %d 进程名称: %s\n",pe32.th32ProcessID, Is64BitPorcess(pe32.th32ProcessID), pe32.szExeFile);bMore = Process32Next(hProcessSnap, &pe32);}system("pause");return 0;
}

本文作者: 王瑞
版权声明: 本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!

http://www.lryc.cn/news/174021.html

相关文章:

  • 你写过的最蠢的代码是?
  • MySQL与PostgreSQL对比
  • AD拼板技巧
  • Android滑动片段
  • 【力扣-每日一题】337. 打家劫舍 III
  • Docker部署FastDFS分布式存储
  • MyBatis基础之SqlSession
  • 笔记本电脑没有麦克风,声音无法找到输入设备
  • MySQL基础—从零开始学习MySQL
  • 单例模式设计
  • 轻量型服务器能支撑多少人访问?
  • python: Sorting Algorithms
  • Python 安装js环境
  • 2023华为杯数模C题——大规模创新类竞赛评审方案研究
  • 人工神经网络ANN:数学总结
  • RabbitMQ的工作模式——WorkQueues
  • AOJ 0531 坐标离散化
  • Python —— pytest框架
  • IP地址欺骗的危害与后果
  • 系统集成|第十章(笔记)
  • Linux之perf(7)配置
  • 14:00面试,14:06就出来了,问的问题过于变态了。。。
  • JPA的注解@Field指定为Keyword失败,导致查询不到数据
  • 多线程带来的的风险-线程安全
  • Kafka 面试题
  • 离线部署 python 3.x 版本
  • Java 获取豆瓣电影TOP250
  • 笔试面试相关记录(5)
  • 四、C#—变量,表达式,运算符(2)
  • 【WSN】基于蚁群算法的WSN路由协议(最短路径)消耗节点能量研究(Matlab代码实现)