本文整理匯總了C++中GetProcessId函數的典型用法代碼示例。如果您正苦於以下問題:C++ GetProcessId函數的具體用法?C++ GetProcessId怎麽用?C++ GetProcessId使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了GetProcessId函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C++代碼示例。
示例1: AppDrone
VOID
AppDrone() {
ULONG i, j;
HANDLE outp;
CHAR outstring[80];
outp = CreateFile('s');
RtlFormatString(outstring, 80, "\r\nDrone with PID:%d started\r\n", GetProcessId());
WriteString(outp, outstring);
KdPrint("in drone 1");
//Sleep(DRONE_SLEEP_TIME);
KdPrint("in drone after sleep");
RtlFormatString(outstring, 80, "\r\nDrone with PID:%d still alive\r\n", GetProcessId());
for (i = 0; i < 3; i++) {
KdPrint("in drone 2");
WriteString(outp, outstring);
for(j=0;j<0xFFFFFF;j++);
//Sleep(DRONE_SLEEP_TIME);
}
RtlFormatString(outstring, 80, "\r\nDrone with PID:%d killing my self\r\n", GetProcessId());
KdPrint("in drone 3");
WriteString(outp, outstring);
CloseHandle(outp);
KillMe();
}
示例2: CaptureAndSuspendProcess
DWORD CALLBACK CaptureAndSuspendProcess(LPVOID)
{
ImpersonateAnonymousToken(GetCurrentThread());
while (NtGetNextProcess(nullptr, MAXIMUM_ALLOWED, 0, 0, &g_hProcess) != 0)
{
}
NTSTATUS status = NtSuspendProcess(g_hProcess);
printf("Suspended process: %08X %p %d\n", status, g_hProcess, GetProcessId(g_hProcess));
RevertToSelf();
SetProcessId(GetProcessId(g_hProcess));
WCHAR cmdline[] = L"notepad.exe";
STARTUPINFO startInfo = {};
PROCESS_INFORMATION procInfo = {};
startInfo.cb = sizeof(startInfo);
if (CreateProcessWithLogonW(L"user", L"domain", L"password", LOGON_NETCREDENTIALS_ONLY,
nullptr, cmdline, CREATE_SUSPENDED, nullptr, nullptr, &startInfo, &procInfo))
{
printf("Created process %d\n", procInfo.dwProcessId);
}
else
{
printf("Create error: %d\n", GetLastError());
}
TerminateProcess(g_hProcess, 0);
ExitProcess(0);
return 0;
}
示例3: waitpid
void FProcState::Wait()
{
if (bHasBeenWaitedFor)
{
return; // we could try waitpid() another time, but why
}
for(;;) // infinite loop in case we get EINTR and have to repeat
{
siginfo_t SignalInfo;
if (waitid(P_PID, GetProcessId(), &SignalInfo, WEXITED))
{
if (errno != EINTR)
{
int ErrNo = errno;
UE_LOG(LogHAL, Fatal, TEXT("FLinuxPlatformProcess::WaitForProc: waitid for pid %d failed (errno=%d, %s)"),
static_cast< int32 >(GetProcessId()), ErrNo, ANSI_TO_TCHAR(strerror(ErrNo)));
break; // exit the loop if for some reason Fatal log (above) returns
}
}
else
{
check(SignalInfo.si_pid == GetProcessId());
ReturnCode = (SignalInfo.si_code == CLD_EXITED) ? SignalInfo.si_status : -1;
bHasBeenWaitedFor = true;
bIsRunning = false; // set in advance
break;
}
}
}
示例4: MyCreateProcessCommon
static void
MyCreateProcessCommon(BOOL bRet,
DWORD dwCreationFlags,
LPPROCESS_INFORMATION lpProcessInformation)
{
if (!bRet) {
debugPrintf("inject: warning: failed to create child process\n");
return;
}
DWORD dwLastError = GetLastError();
if (isDifferentArch(lpProcessInformation->hProcess)) {
debugPrintf("inject: error: child process %lu has different architecture\n",
GetProcessId(lpProcessInformation->hProcess));
} else {
char szDllPath[MAX_PATH];
GetModuleFileNameA(g_hThisModule, szDllPath, sizeof szDllPath);
if (!injectDll(lpProcessInformation->hProcess, szDllPath)) {
debugPrintf("inject: warning: failed to inject into child process %lu\n",
GetProcessId(lpProcessInformation->hProcess));
}
}
if (!(dwCreationFlags & CREATE_SUSPENDED)) {
ResumeThread(lpProcessInformation->hThread);
}
SetLastError(dwLastError);
}
示例5: PsProcessHandleToId
DWORD
PsProcessHandleToId(HANDLE ProcessHandle)
{
HANDLE targetHandle;
DWORD processId;
if (ProcessHandle == GetCurrentProcess())
{
return GetCurrentProcessId();
}
processId = GetProcessId(ProcessHandle);
if (processId)
{
return processId;
}
if (!PsCopyHandle(GetCurrentProcess(),
ProcessHandle,
&targetHandle,
PROCESS_QUERY_INFORMATION,
FALSE))
{
return 0;
}
processId = GetProcessId(targetHandle);
CloseHandle(targetHandle);
return processId;
}
示例6: main
int main(int argc, char* argv[])
{
int a = fork();
char *env[] = {"PATH=C:\\TEST", NULL};
if(a > 0)
{
printf("\nParent ProcessID : %d\n",GetProcessId());
waitpid(a);
printf("\nAfter Child Process has exited");
sleep(10);
printf("\nParent : After Sleep");
}
else
{
printf("\nChild ProcessID : %d\n",GetProcessId());
char *inp[] = {"bin/hello","a","b"};
execvpe(inp[0],inp,env);
}
return 0;
}
示例7: check
bool FProcState::IsRunning()
{
if (bIsRunning)
{
check(!bHasBeenWaitedFor); // check for the sake of internal consistency
// check if actually running
int KillResult = kill(GetProcessId(), 0); // no actual signal is sent
check(KillResult != -1 || errno != EINVAL);
bIsRunning = (KillResult == 0 || (KillResult == -1 && errno == EPERM));
// additional check if it's a zombie
if (bIsRunning)
{
for(;;) // infinite loop in case we get EINTR and have to repeat
{
siginfo_t SignalInfo;
SignalInfo.si_pid = 0; // if remains 0, treat as child was not waitable (i.e. was running)
if (waitid(P_PID, GetProcessId(), &SignalInfo, WEXITED | WNOHANG | WNOWAIT))
{
if (errno != EINTR)
{
int ErrNo = errno;
UE_LOG(LogHAL, Fatal, TEXT("FLinuxPlatformProcess::WaitForProc: waitid for pid %d failed (errno=%d, %s)"),
static_cast< int32 >(GetProcessId()), ErrNo, ANSI_TO_TCHAR(strerror(ErrNo)));
break; // exit the loop if for some reason Fatal log (above) returns
}
}
else
{
bIsRunning = ( SignalInfo.si_pid != GetProcessId() );
break;
}
}
}
// If child is a zombie, wait() immediately to free up kernel resources. Higher level code
// (e.g. shader compiling manager) can hold on to handle of no longer running process for longer,
// which is a dubious, but valid behavior. We don't want to keep zombie around though.
if (!bIsRunning)
{
UE_LOG(LogHAL, Log, TEXT("Child %d is no more running (zombie), Wait()ing immediately."), GetProcessId() );
Wait();
}
}
return bIsRunning;
}
示例8: Log
void Log(char* szFormat, ...)
{
va_list vaArgs;
va_start(vaArgs, szFormat);
int len = _vscprintf(szFormat, vaArgs);
char* szString = new char[len+1];
vsprintf_s(szString, len+1, szFormat, vaArgs);
va_end(vaArgs);
time_t tTime;
time(&tTime);
char szTime[128] = "";
struct tm time;
localtime_s(&time, &tTime);
strftime(szTime, sizeof(szTime), "%x %X", &time);
char path[_MAX_PATH+_MAX_FNAME] = "";
sprintf_s(path, sizeof(path), "%sd2bs.log", Vars.szPath);
#ifdef DEBUG
FILE* log = stderr;
#else
FILE* log = _fsopen(path, "a+", _SH_DENYNO);
#endif
fprintf(log, "[%s] D2BS %d: %s\n", szTime, GetProcessId(GetCurrentProcess()), szString);
#ifndef DEBUG
fflush(log);
fclose(log);
#endif
delete[] szString;
}
示例9: C_GetProcMemInfo
BOOL MEMINFO_API C_GetProcMemInfo(_In_ DWORD dwProcId, _Out_ PPROCMEMINFO_C pProcMemInfo){
HANDLE hProc = NULL;
MEMORYSTATUSEX status;
PROCESS_MEMORY_COUNTERS procMemCtr;
printf("\n\n~~~~ INFORMACAO LOCAL DO PROCESSO ~~~~~");
status.dwLength = sizeof (status);
if (hProc = OpenProcess(PROCESS_VM_READ|PROCESS_QUERY_INFORMATION, FALSE, dwProcId) == NULL || !GlobalMemoryStatusEx(&status) ||
!GetProcessMemoryInfo(hProc, &procMemCtr, sizeof(PROCESS_MEMORY_COUNTERS))){
printf("ERROR: %s\n", GetLastError());
return FALSE;
}
printf("\nProcess ID = %u", GetProcessId(hProc));
printf("\nTotal de espaco de enderecamento virtual existente: %llu KiB = %llu MiB", status.ullTotalVirtual / KiloB, status.ullTotalVirtual / MegaB);
printf("\nTotal de espaco de enderecamento virtual disponivel: %llu KiB = %llu MiB", status.ullAvailVirtual / KiloB, status.ullAvailVirtual / MegaB);
printf("\nDimensao do Working Set: %u KiB = %.2f MiB", procMemCtr.WorkingSetSize / KiloB, (double)procMemCtr.WorkingSetSize / MegaB);
// Afectar a struct _out_
pProcMemInfo->processId = dwProcId;
pProcMemInfo->workingSetSize = procMemCtr.WorkingSetSize;
pProcMemInfo->totalVirtualSpace = status.ullTotalVirtual;
pProcMemInfo->availableVirtualSpace = status.ullAvailVirtual;
printf("\n\nClique em qualquer tecla para terminar..."); getchar();
CloseHandle(hProc);
return TRUE;
}
示例10: GetProcessId
int KProcess::getProcessId() {
#ifdef _WIN32
return GetProcessId(pid);
#else
return pid;
#endif
}
示例11: fork
int
fork(void)
{
RTL_USER_PROCESS_INFORMATION info;
NTSTATUS result;
if (w32_fork == NULL)
return -ENOSYS;
/* lets do this */
result = w32_fork(RTL_CLONE_FLAGS, NULL, NULL, NULL, &info);
if (result == CLONE_PARENT) {
pid_t pid = GetProcessId(info.Process);
ResumeThread(info.Thread);
CloseHandle(info.Process);
CloseHandle(info.Thread);
return pid;
} else if (result == CLONE_CHILD) {
/* fix stdio */
AllocConsole();
return 0;
} else
return -1;
return -1;
}
示例12: qDebug
void CdbDumperHelper::moduleLoadHook(const QString &module, HANDLE debuggeeHandle)
{
if (loadDebug > 1)
qDebug() << "moduleLoadHook" << module << m_state << debuggeeHandle;
switch (m_state) {
case Disabled:
case Initialized:
break;
case NotLoaded:
// Try an inject load as soon as a Qt lib is loaded.
// for the thread to finish as this would lock up.
if (m_tryInjectLoad && module.contains(QLatin1String("Qt"), Qt::CaseInsensitive)) {
// Also shows up in the log window.
m_manager->showStatusMessage(msgLoading(m_library, true), messageTimeOut);
QString errorMessage;
SharedLibraryInjector sh(GetProcessId(debuggeeHandle));
if (sh.remoteInject(m_library, false, &errorMessage)) {
m_state = InjectLoading;
} else {
m_state = InjectLoadFailed;
// Ok, try call loading...
m_manager->showDebuggerOutput(LogMisc, msgLoadFailed(m_library, true, errorMessage));
}
}
break;
case InjectLoading:
// check if gdbmacros.dll loaded
if (module.contains(QLatin1String(dumperModuleNameC), Qt::CaseInsensitive)) {
m_state = Loaded;
m_manager->showDebuggerOutput(LogMisc, msgLoadSucceeded(m_library, true));
}
break;
}
}
示例13: evalProcesses
int evalProcesses(HANDLE hProcess)
{
if (NULL == hProcess)
return 0;
unsigned int totalMemUsage = 0;
DWORD processID = GetProcessId(hProcess);
HANDLE hProcessSnapshot = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);
PROCESSENTRY32 processEntry = { 0 };
processEntry.dwSize = sizeof(PROCESSENTRY32);
// Retrieves information about the first process encountered in a system snapshot
if(Process32First(hProcessSnapshot, &processEntry)) {
do {
// if th32processID = processID, we are the parent process!
// if th32ParentProcessID = processID, we are a child process!
if ((processEntry.th32ProcessID == processID) || (processEntry.th32ParentProcessID == processID)) {
unsigned int procMemUsage = 0;
// Record parent process memory
procMemUsage = getMemoryInfo(processEntry.th32ProcessID);
totalMemUsage += procMemUsage;
}
// Retrieves information about the next process recorded in a system snapshot.
} while(Process32Next(hProcessSnapshot, &processEntry));
}
CloseHandle(hProcessSnapshot);
return totalMemUsage;
}
示例14: OpenProcess
bool
Application_ClientConfigManager::closeProcess(DWORD processId, DWORD* error)
{
HANDLE hProcess = OpenProcess(PROCESS_TERMINATE,TRUE, processId);
if(hProcess == NULL)
{
*error = GetLastError();
if(*error == ERROR_INVALID_PARAMETER)
{
*error = CAPTURE_PE_PROCESS_ALREADY_TERMINATED;
}
} else {
EnumWindows(Application_ClientConfigManager::EnumWindowsProc, (LPARAM)processId);
DWORD tempProcessId = GetProcessId(hProcess);
if(tempProcessId == processId)
{
if(!TerminateProcess(hProcess, 0))
{
*error = GetLastError();
} else {
*error = CAPTURE_PE_PROCESS_TERMINATED_FORCEFULLY;
}
} else {
return true;
}
}
return false;
}
示例15: AppIsAlreadyRunning
BOOL AppIsAlreadyRunning()
{
BOOL bRunning=FALSE;
CString strAppName;
strAppName = "ZuneNowPlaying.exe";
DWORD dwOwnPID = GetProcessId(GetCurrentProcess());
HANDLE hSnapShot=CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS,0);
PROCESSENTRY32* processInfo=new PROCESSENTRY32;
processInfo->dwSize=sizeof(PROCESSENTRY32);
int index=0;
while(Process32Next(hSnapShot,processInfo)!=FALSE)
{
CString pName = (LPCWSTR)processInfo->szExeFile;
if (pName.CompareNoCase(strAppName) == 0)
{
if (processInfo->th32ProcessID != dwOwnPID)
{
bRunning=TRUE;
break;
}
}
}
CloseHandle(hSnapShot);
delete processInfo;
return bRunning;
}