C++實現(xiàn)結(jié)束應(yīng)用進(jìn)程小工具
C++實現(xiàn)結(jié)束應(yīng)用進(jìn)程小工具(windows)
說明:
在電腦上一些軟件或系統(tǒng)有時可能會將程序偷偷運(yùn)行在后臺,占用計算機(jī)資源的情況。一般我們通過可以找到程序文件所在位置,禁止程序啟動的方法解決這個問題,但也可以通過從任務(wù)管理器直接結(jié)束進(jìn)程方法做到。從而減少無用程序?qū)τ嬎銠C(jī)資源的占用。
該程序可以自動檢查設(shè)定進(jìn)程名稱的進(jìn)程是否正在運(yùn)行,如果是則結(jié)束該進(jìn)程,從而免去手動關(guān)閉的步驟。
使用步驟為在該程序exe文件目錄下names.txt文件中(可改變)將需要結(jié)束的進(jìn)程名寫在文件中,多個進(jìn)程名以換行分割,然后點擊exe程序執(zhí)行。
思路:
封裝獲取系統(tǒng)進(jìn)程名稱、id、結(jié)束系統(tǒng)進(jìn)程方法。從文件中獲取需要結(jié)束進(jìn)程的名稱,根據(jù)名稱結(jié)束進(jìn)程。
編譯環(huán)境:
Windows VS2017
代碼需要在支持C++11標(biāo)準(zhǔn)的編譯器下編譯
代碼:
#include <iostream> #include <windows.h> #include <tlhelp32.h> #include <vector> #include <fstream> #include <map> using namespace std; // 需要關(guān)閉進(jìn)程名字所在文件路徑 #define CLOSE_FILE_PATH "names.txt" // 每CHECK_INTERVAL時間(毫秒)后檢查并結(jié)束一次進(jìn)程 #define CHECK_INTERVAL 3000 class Controller { private: // 進(jìn)程信息結(jié)構(gòu)體,包含進(jìn)程id和進(jìn)程名 struct PInfo { long pId; wchar_t *pName; PInfo(long pId, wchar_t *pName) : pId(pId), pName(pName) {} }; // 根據(jù)pid關(guān)閉進(jìn)程 static int closeProcess(unsigned long pid) { HANDLE hProcess = OpenProcess(PROCESS_TERMINATE, FALSE, pid); if (hProcess) { TerminateProcess(hProcess, -1); } return 0; } // 獲取所有進(jìn)程信息 static map<wstring, long> getProcessInfo() { HANDLE hProcess = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0); PROCESSENTRY32 currentProcess; currentProcess.dwSize = sizeof(currentProcess); map<wstring, long> pInfosMap = map<wstring, long>(); Process32First(hProcess, ¤tProcess); wchar_t *pNameStr; bool flag = true; while (flag) { pNameStr = new WCHAR[MAX_PATH]; // wcscpy(pNameStr, currentProcess.szExeFile); wcscpy_s(pNameStr, wcslen(currentProcess.szExeFile) + 1, currentProcess.szExeFile); pInfosMap.insert(pair<wstring, long>(pNameStr, currentProcess.th32ProcessID)); flag = Process32Next(hProcess, ¤tProcess); } return pInfosMap; } // char*轉(zhuǎn)wchar* static wchar_t * charToWchar(const char* cchar) { wchar_t *m_wchar; int len = MultiByteToWideChar(CP_ACP, 0, cchar, strlen(cchar), NULL, 0); m_wchar = new wchar_t[len + 1]; MultiByteToWideChar(CP_ACP, 0, cchar, strlen(cchar), m_wchar, len); m_wchar[len] = '\0'; return m_wchar; } // 循環(huán)獲取需要關(guān)閉的進(jìn)程名 template <typename Callback> static void forClosePName(Callback callback) { ifstream examplefile(CLOSE_FILE_PATH); if (!examplefile.is_open()) { cout << "Error opening file"; exit(1); } char buffer[260]; while (!examplefile.eof()) { examplefile.getline(buffer, 260); callback(buffer); } } // 將需要關(guān)閉的進(jìn)程名保存到vector<wchar_t*>中返回 vector<wchar_t*> getClosePName() { vector<wchar_t*> closePNames = vector<wchar_t*>(); forClosePName([&](auto pName) { closePNames.push_back(charToWchar(pName)); }); return closePNames; } public: Controller() { // 需要結(jié)束的進(jìn)程名 vector<wchar_t*> closePNames = getClosePName(); // 所有進(jìn)程信息map map<wstring, long> processMap; while (true) { processMap = getProcessInfo(); for (auto pName : closePNames) { //printf("%ls \n", pName); long closePId = processMap[pName]; if (closePId == 0 || wstring(pName) == L"系統(tǒng)空閑進(jìn)程") continue; closeProcess(closePId); } Sleep(CHECK_INTERVAL); } } }; int main() { Controller(); return 0; }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
對比C語言中g(shù)etc()函數(shù)和ungetc()函數(shù)的使用
這篇文章主要介紹了對比C語言中g(shù)etc()函數(shù)和ungetc()函數(shù)的使用,是C語言入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下2015-08-08C語言超詳細(xì)講解循環(huán)與分支語句基礎(chǔ)
各位小伙伴們,今天給大家?guī)淼氖茄h(huán)與分支語句,本篇將會向大家介紹這些語句的格式和使用的基本方法,感興趣的朋友來看看吧2022-04-04VS2022創(chuàng)建Windows服務(wù)程序的方法步驟
本文主要介紹了VS2022創(chuàng)建Windows服務(wù)程序的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-05-05c++ 求數(shù)組最大最小值函數(shù)的實現(xiàn)
這篇文章主要介紹了c++ 求數(shù)組最大最小值函數(shù)的實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-07-07將CString字符串輸入轉(zhuǎn)化成整數(shù)的實現(xiàn)方法
下面小編就為大家?guī)硪黄獙String字符串輸入轉(zhuǎn)化成整數(shù)的實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-09-09VS2019配置OpenCV時找不到Microsoft.Cpp.x64.user的解決方法
這篇文章主要介紹了VS2019配置OpenCV時找不到Microsoft.Cpp.x64.user的解決方法,需要的朋友可以參考下2020-02-02C語言數(shù)據(jù)結(jié)構(gòu)之二叉樹詳解
二叉樹(Binary tree)是樹形結(jié)構(gòu)的一個重要類型。許多實際問題抽象出來的數(shù)據(jù)結(jié)構(gòu)往往是二叉樹形式。本文將通過示例詳細(xì)講解一下二叉樹,需要的可以參考一下2022-03-03