QT_获取运行进程所在目录路径_2
QString getProcessFullPath(const quint64 &processId) { #ifdef Q_OS_WIN // access process path WCHAR name[1024]; ZeroMemory(name, 1024); // open process handler HANDLE hProcess = OpenProcess(PROCESS_QUERY_INFORMATION | PROCESS_VM_READ, FALSE, processId); if (NULL != hProcess) { DWORD cbNeeded; HMODULE hMod; // process path if (EnumProcessModules(hProcess, &hMod, sizeof(hMod), &cbNeeded)) { DWORD dw = GetModuleFileNameExW(hProcess, hMod, name, 1024); } CloseHandle(hProcess); } return QString::fromWCharArray(name); #elif defined Q_OS_MAC #include <libproc.h> char pathbuf[1024]; proc_pidpath(processId, pathbuf, sizeof(pathbuf)); qDebug() << "running process path: " << pathbuf; // //const char* strFind_ComName = convertQString2char("ps -ef|grep processName |grep -v grep |awk '{print $8}'"); // QString strCommand = "ps -ef|grep " + processName + " |grep -v grep |awk '{print $2}'"; // const char* strFind_ComName = convertQString2char(strCommand); // FILE * pPipe = popen(strFind_ComName, "r"); // if (pPipe) // { // std::string com; // char name[512] = { 0 }; // while (fgets(name, sizeof(name), pPipe) != NULL) // { // int nLen = strlen(name); // if (nLen > 0 // && name[nLen - 1] == '\n' // && name[0] == '/') // { // name[nLen - 1] = '\0'; // strPath = name; // break; // } // } // pclose(pPipe); // } // qDebug() << "----------------------------------------- check processName strPath " << strPath; QString strPath(pathbuf); return strPath; #endif }
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
作者:风来风往风伤
出处:http://www.cnblogs.com/amwuau/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接,否则保留追究法律责任的权利。