Экспертная система Delphi.int.ru

Сообщество программистов
Общение, помощь, обмен опытом

Логин:
Пароль:
Регистрация | Забыли пароль?

Delphi.int.ru Expert

Другие разделы портала

Переход к вопросу:

#   

Статистика за сегодня:  


Лучшие эксперты

Подробнее »



Вопрос # 2 895

Раздел: Delphi » Прочее
/ вопрос открыт /

Приветствую, уважаемые эксперты!
Сразу прошу прощения за такой дурной вопрос. Но мне очень нужно разобраться в коде, который осуществляет определение загрузки центрального процессора. Понять сам алгоритм, как происходит определение этого значения.
Заранее благодарю за ответы!

Приложение:
  1.  
  2. function GetCPUUsage: Integer;
  3. var
  4. SysBaseInfo: TSystem_Basic_Information;
  5. SysPerfInfo: TSystem_Performance_Information;
  6. SysTimeInfo: TSystem_Time_Information;
  7. status: Longint;
  8. dbSystemTime: Double;
  9. dbIdleTime: Double;
  10. begin
  11. if @NtQuerySystemInformation = nil then
  12. NtQuerySystemInformation := GetProcAddress(GetModuleHandle('ntdll.dll'),
  13. 'NtQuerySystemInformation');
  14. status := NtQuerySystemInformation(0, @SysBaseInfo, SizeOf(SysBaseInfo), nil);
  15. if status <> 0 then Exit;
  16. status := NtQuerySystemInformation(3, @SysTimeInfo, SizeOf(SysTimeInfo), 0);
  17. if status <> 0 then Exit;
  18. status := NtQuerySystemInformation(2, @SysPerfInfo, SizeOf(SysPerfInfo), nil);
  19. if status <> 0 then Exit;
  20. liOldIdleTime := SysPerfInfo.liIdleTime;
  21. liOldSystemTime := SysTimeInfo.liKeSystemTime;
  22. Sleep(1000);
  23. status := NtQuerySystemInformation(3, @SysTimeInfo, SizeOf(SysTimeInfo), 0);
  24. if status <> 0 then Exit;
  25. status := NtQuerySystemInformation(2, @SysPerfInfo, SizeOf(SysPerfInfo), nil);
  26. if status <> 0 then Exit;
  27. dbIdleTime := Li2Double(SysPerfInfo.liIdleTime) - Li2Double(liOldIdleTime);
  28. dbSystemTime := Li2Double(SysTimeInfo.liKeSystemTime) - Li2Double(liOldSystemTime);
  29. dbIdleTime := dbIdleTime / dbSystemTime;
  30. dbIdleTime := 100 - dbIdleTime * 100;
  31. result:= Trunc(dbIdleTime) + Trunc (Frac(dbIdleTime) * 2);
  32. end;
  33.  


Insomnia Вопрос ожидает решения (принимаются ответы, доступен мини-форум)

Вопрос задала: Insomnia (статус: Посетитель)
Вопрос отправлен: 10 июня 2009, 15:05
Состояние вопроса: открыт, ответов: 1.

Ответ #1. Отвечает эксперт: Пупкин В В

Здравствуйте, Insomnia!
узнается количество процессоров
потом каждую секунду получаем время простоя и загргрузки проца т.к. винда любит считать время от "начала времен"
вычитаем получая время которое реально работает и бездействует проц
получаем соотношение времен, а затем переводим в проценты учитывая сколько у нас процессоров
вот и все
я так понял по крайней мере =)

Ответ отправил: Пупкин В В (статус: 2-ой класс)
Время отправки: 10 июня 2009, 16:17


Мини-форум вопроса

Всего сообщений: 1; последнее сообщение — 10 июня 2009, 16:24; участников в обсуждении: 1.
Пупкин В В

Пупкин В В (статус: 2-ой класс), 10 июня 2009, 16:24 [#1]:

хотя меня смущает
result:= Trunc(dbIdleTime) + Trunc (Frac(dbIdleTime) * 2);
и то что не учитываем количество процессоров
вернее тут он один наверно
код то 100% рабочий? показывает верный результат?

Чтобы оставлять сообщения в мини-форумах, Вы должны авторизироваться на сайте.

Версия движка: 2.6+ (26.01.2011)
Текущее время: 22 февраля 2025, 11:30
Выполнено за 0.03 сек.