開發(fā)公司英文企業(yè)站seo
進(jìn)程狀態(tài)的判斷包括驗(yàn)證進(jìn)程是否存在,實(shí)現(xiàn)方法是通過枚舉系統(tǒng)內(nèi)的所有進(jìn)程信息,并將該進(jìn)程名通過CharLowerBuff
轉(zhuǎn)換為小寫,當(dāng)轉(zhuǎn)換為小寫模式后則就可以通過使用strcmp
函數(shù)對(duì)比,如果發(fā)現(xiàn)繼承存在則返回該進(jìn)程的PID信息,否則返回-1。
int GetProcessStatus(const char *procressName)
{char pName[MAX_PATH];strcpy(pName, procressName); // 拷貝數(shù)組CharLowerBuff(pName, MAX_PATH); // 將名稱轉(zhuǎn)換為小寫PROCESSENTRY32 currentProcess; // 存放快照進(jìn)程信息的一個(gè)結(jié)構(gòu)體currentProcess.dwSize = sizeof(currentProcess); // 在使用這個(gè)結(jié)構(gòu)之前,先設(shè)置它的大小HANDLE hProcess = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0); // 給系統(tǒng)內(nèi)的所有進(jìn)程拍一個(gè)快照if (INVALID_HANDLE_VALUE != hProcess){BOOL bMore = Process32First(hProcess, ¤tProcess);while (bMore){CharLowerBuff(currentProcess.szExeFile, MAX_PATH); // 將進(jìn)程名轉(zhuǎn)換為小寫if (strcmp(currentProcess.szExeFile, pName) == 0) // 比較是否存在此進(jìn)程{CloseHandle(hProcess);return currentProcess.th32ProcessID;}bMore = Process32Next(hProcess, ¤tProcess);}CloseHandle(hProcess);}return -1;
}
有時(shí)候我們需要判斷自身進(jìn)程是否被重復(fù)運(yùn)行了,這種需求在軟件開發(fā)中經(jīng)常會(huì)遇到,通常該需求可以使用CreateMutex
創(chuàng)建或打開一個(gè)互斥量對(duì)象(Mutex Object
),在多線程/進(jìn)程的環(huán)境下,互斥量可用于控制對(duì)某個(gè)共享資源的訪問。其函數(shù)聲明如下:
HANDLE CreateMutex(LPSECURITY_ATTRIBUTES lpMutexAttributes,BOOL bInitialOwner,LPCTSTR lpName
);
其中,lpMutexAttributes
是用于指定新創(chuàng)建的互斥量的安全描述符的指針;bInitialOwner
表示一個(gè)布爾值,指定初始所有權(quán)標(biāo)記,為 TRUE
表示調(diào)用線程將擁有該互斥量,否則表示它不屬于調(diào)用線程;lpName
是可選的,用于命名互斥體,以使得其他線程或者進(jìn)程可以通過這個(gè)名字來打開該互斥量對(duì)象。
CreateMutex 函數(shù)會(huì)返回一個(gè)內(nèi)核對(duì)象句柄,用于在之后對(duì)該互斥體進(jìn)行引用和操作,通過使用互斥體可以很容易的實(shí)現(xiàn)對(duì)進(jìn)程運(yùn)行狀態(tài)的判斷。
#include <Windows.h>
#include <stdio.h>// 判斷是否重復(fù)運(yùn)行
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("重復(fù)運(yùn)行 \n");elseprintf("沒有重復(fù)運(yùn)行 \n");system("pause");return 0;
}
對(duì)進(jìn)程位數(shù)的判斷也是有必要的,通常在Windows系統(tǒng)下進(jìn)程位數(shù)的有多種方法實(shí)現(xiàn),第一種方式GetNativeSystemInfo
調(diào)用該函數(shù)并判斷函數(shù)內(nèi)的特定成員,即可得到當(dāng)前系統(tǒng)是否為64位,當(dāng)然通過使用Is64BitPorcess
函數(shù)也可實(shí)現(xiàn)對(duì)特定進(jìn)程的判斷,此方式實(shí)現(xiàn)原理是通過調(diào)用IsWow64Process
函數(shù)實(shí)現(xiàn);
#include <stdio.h>
#include <Windows.h>
#include <tlhelp32.h>// 判斷自身系統(tǒng)是否為64位
BOOL IsSelf64bitSystem()
{SYSTEM_INFO si;GetNativeSystemInfo(&si);if (si.wProcessorArchitecture == PROCESSOR_ARCHITECTURE_AMD64 ||si.wProcessorArchitecture == PROCESSOR_ARCHITECTURE_IA64)return TRUE;elsereturn FALSE;
}// 判斷指定進(jìn)程是否為64位進(jìn)程
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("進(jìn)程PID: %5d 是否64位: %d 進(jìn)程名稱: %s\n",pe32.th32ProcessID, Is64BitPorcess(pe32.th32ProcessID), pe32.szExeFile);bMore = Process32Next(hProcessSnap, &pe32);}system("pause");return 0;
}
本文作者: 王瑞
版權(quán)聲明: 本博客所有文章除特別聲明外,均采用 BY-NC-SA 許可協(xié)議。轉(zhuǎn)載請注明出處!