Легенда:
новое сообщение
закрытая нитка
новое сообщение
в закрытой нитке
старое сообщение
|
- Напоминаю, что масса вопросов по функционированию форума снимается после прочтения его описания.
- Новичкам также крайне полезно ознакомиться с данным документом.
| |
Только один OFF вопрос 06.11.02 00:02 Число просмотров: 1073
Автор: PS <PS> Статус: Elderman
|
Как ты догадался это найти ?
Вопрос на самом деле не простой, и не такой уж и ОФФ. Интересен алгоритм в голове, по которому формируется запрос к DB (в данном случае MSDN).
Первое что приходит в голову искать GetProcess..., GetThread..., ThreadSet..., ect...
Но какой "извращенной" логикой нужно обладать, что бы начать искать CreateToolhelp32Snapshot ? Даже поставить 32 после Thread - не тривиально...
Вообщем - спасибо :)
|
<programming>
|
[Win32] Как получить id потоков в заданом процессе ? 05.11.02 17:05
Автор: PS <PS> Статус: Elderman
|
MSDN мне не помог.
P.S. Кстати, а как мне найти ppid ? Весело, а ведь даже TaskManager и тот ppid не выдает... странно.
|
|
[Win32] Как получить id потоков в заданом процессе ? 05.11.02 21:08
Автор: Cyril <sc> Статус: Member
|
> MSDN мне не помог. > > P.S. Кстати, а как мне найти ppid ? Весело, а ведь даже > TaskManager и тот ppid не выдает... странно. Platform SDK: Performance Monitoring
Traversing the Thread List
The following example obtains a list of running threads for the specified process. First, the RefreshThreadList function takes a snapshot of the currently executing threads in the system using the CreateToolhelp32Snapshot function, then it walks through the list recorded in the snapshot, using the Thread32First and Thread32Next functions. The parameter for RefreshThreadList is the identifier of the process whose threads will be listed.
#include <windows.h>
#include <tlhelp32.h>
#include <stdio.h>
BOOL RefreshThreadList (DWORD dwOwnerPID)
{
HANDLE hThreadSnap = NULL;
BOOL bRet = FALSE;
THREADENTRY32 te32 = {0};
// Take a snapshot of all threads currently in the system.
hThreadSnap = CreateToolhelp32Snapshot(TH32CS_SNAPTHREAD, 0);
if (hThreadSnap == INVALID_HANDLE_VALUE)
return (FALSE);
// Fill in the size of the structure before using it.
te32.dwSize = sizeof(THREADENTRY32);
// Walk the thread snapshot to find all threads of the process.
// If the thread belongs to the process, add its information
// to the display list.
if (Thread32First(hThreadSnap, &te32))
{
do
{
if (te32.th32OwnerProcessID == dwOwnerPID)
{
printf( "\nTID\t\t%d\n", te32.th32ThreadID);
printf( "Owner PID\t%d\n", te32.th32OwnerProcessID);
printf( "Delta Priority\t%d\n", te32.tpDeltaPri);
printf( "Base Priority\t%d\n", te32.tpBasePri);
}
}
while (Thread32Next(hThreadSnap, &te32));
bRet = TRUE;
}
else
bRet = FALSE; // could not walk the list of threads
// Do not forget to clean up the snapshot object.
CloseHandle (hThreadSnap);
return (bRet);
}
---
первоисточник :)
|
| |
Только один OFF вопрос 06.11.02 00:02
Автор: PS <PS> Статус: Elderman
|
Как ты догадался это найти ?
Вопрос на самом деле не простой, и не такой уж и ОФФ. Интересен алгоритм в голове, по которому формируется запрос к DB (в данном случае MSDN).
Первое что приходит в голову искать GetProcess..., GetThread..., ThreadSet..., ect...
Но какой "извращенной" логикой нужно обладать, что бы начать искать CreateToolhelp32Snapshot ? Даже поставить 32 после Thread - не тривиально...
Вообщем - спасибо :)
|
| | |
имена функций - плод фантазии разработчиков API 06.11.02 00:28
Автор: beetle <beetle> Статус: Member
|
> Как ты догадался это найти ? > Вопрос на самом деле не простой, и не такой уж и ОФФ. > Интересен алгоритм в голове, по которому формируется запрос > к DB (в данном случае MSDN). > Первое что приходит в голову искать GetProcess..., > GetThread..., ThreadSet..., ect... > Но какой "извращенной" логикой нужно обладать, что бы > начать искать CreateToolhelp32Snapshot ? Даже поставить 32 > после Thread - не тривиально... RTFM
это по ходу дела стандартные функции Win32 API
есть более продвинутые PS API - но они только для NT/2K
|
|
|