您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關(guān)C++如何實(shí)現(xiàn)結(jié)束應(yīng)用進(jìn)程小工具的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
C++實(shí)現(xiàn)結(jié)束應(yīng)用進(jìn)程小工具(windows)
在電腦上一些軟件或系統(tǒng)有時可能會將程序偷偷運(yùn)行在后臺,占用計(jì)算機(jī)資源的情況。一般我們通過可以找到程序文件所在位置,禁止程序啟動的方法解決這個問題,但也可以通過從任務(wù)管理器直接結(jié)束進(jìn)程方法做到。從而減少無用程序?qū)τ?jì)算機(jī)資源的占用。
該程序可以自動檢查設(shè)定進(jìn)程名稱的進(jìn)程是否正在運(yùn)行,如果是則結(jié)束該進(jìn)程,從而免去手動關(guān)閉的步驟。
使用步驟為在該程序exe文件目錄下names.txt文件中(可改變)將需要結(jié)束的進(jìn)程名寫在文件中,多個進(jìn)程名以換行分割,然后點(diǎn)擊exe程序執(zhí)行。
封裝獲取系統(tǒng)進(jìn)程名稱、id、結(jié)束系統(tǒng)進(jìn)程方法。從文件中獲取需要結(jié)束進(jìn)程的名稱,根據(jù)名稱結(jié)束進(jì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.th42ProcessID)); 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; }
感謝各位的閱讀!關(guān)于“C++如何實(shí)現(xiàn)結(jié)束應(yīng)用進(jìn)程小工具”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。