информационная безопасность
без паники и всерьез
 подробно о проектеRambler's Top100
Spanning Tree Protocol: недокументированное применениеГде водятся OGRы
BugTraq.Ru
Русский BugTraq
 Анализ криптографических сетевых... 
 Модель надежности двухузлового... 
 Специальные марковские модели надежности... 
 Бэкдор в xz/liblzma, предназначенный... 
 Три миллиона электронных замков... 
 Doom на газонокосилках 
главная обзор RSN блог библиотека закон бред форум dnet о проекте
bugtraq.ru / форум / programming
Имя Пароль
ФОРУМ
если вы видите этот текст, отключите в настройках форума использование JavaScript
регистрация





Легенда:
  новое сообщение
  закрытая нитка
  новое сообщение
  в закрытой нитке
  старое сообщение
  • Напоминаю, что масса вопросов по функционированию форума снимается после прочтения его описания.
  • Новичкам также крайне полезно ознакомиться с данным документом.
[Win32] Как получить id потоков в заданом процессе ? 05.11.02 21:08  Число просмотров: 1134
Автор: 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); 
}

---

первоисточник :)
<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
1




Rambler's Top100
Рейтинг@Mail.ru


  Copyright © 2001-2024 Dmitry Leonov   Page build time: 0 s   Design: Vadim Derkach