информационная безопасность
без паники и всерьез
 подробно о проектеRambler's Top100
За кого нас держат?Портрет посетителя
BugTraq.Ru
Русский BugTraq
 Анализ криптографических сетевых... 
 Модель надежности двухузлового... 
 Специальные марковские модели надежности... 
 Очередное исследование 19 миллиардов... 
 Оптимизация ввода-вывода как инструмент... 
 Зловреды выбирают Lisp и Delphi 
главная обзор RSN блог библиотека закон бред форум dnet о проекте
bugtraq.ru / форум / programming
Имя Пароль
если вы видите этот текст, отключите в настройках форума использование JavaScript
ФОРУМ
все доски
FAQ
IRC
новые сообщения
site updates
guestbook
beginners
sysadmin
programming
operating systems
theory
web building
software
hardware
networking
law
hacking
gadgets
job
dnet
humor
miscellaneous
scrap
регистрация





Легенда:
  новое сообщение
  закрытая нитка
  новое сообщение
  в закрытой нитке
  старое сообщение
имена функций - плод фантазии разработчиков API 06.11.02 00:28  Число просмотров: 1168
Автор: beetle <beetle> Статус: Member
<"чистая" ссылка>
> Как ты догадался это найти ?
> Вопрос на самом деле не простой, и не такой уж и ОФФ.
> Интересен алгоритм в голове, по которому формируется запрос
> к DB (в данном случае MSDN).
> Первое что приходит в голову искать GetProcess...,
> GetThread..., ThreadSet..., ect...
> Но какой "извращенной" логикой нужно обладать, что бы
> начать искать CreateToolhelp32Snapshot ? Даже поставить 32
> после Thread - не тривиально...
RTFM
это по ходу дела стандартные функции Win32 API
есть более продвинутые PS API - но они только для NT/2K
<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-2025 Dmitry Leonov   Page build time: 0 s   Design: Vadim Derkach