Создатель диспетчера задач для Windows объяснил нюансы относительно использования ЦП

от автора

Бывший инженер Microsoft Дэйв Пламмер, работавший над добавлением поддержки ZIP-файлов в Windows и меню «Пуск» Windows NT, рассказал, как диспетчер задач на самом деле считывает загрузку ЦП. 

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

«Измерение использования ЦП звучит так, будто это должна быть одна из самых простых задач в вычислительной технике — я имею в виду, либо ЦП занят, либо нет, верно? Это кремний, а не интерпретативный танец. Конечно, вы просто спрашиваете Windows: “Эй, насколько ты занята?”, и она говорит вам 73%, и тогда мы все расходимся по домам пораньше — но ничего из этого не соответствует действительности. Первый неудобный вопрос: “Чем именно занята?“. Занято ли одно ядро ​​или все? Занят ли ЦП прямо сейчас, или в среднем за последнюю секунду или две, или как часто активируется ваш пользовательский интерфейс? Занят ли пользовательский режим, или режим ядра, или время прерывания, или отложенные вызовы процедур, или цикл простоя, или какой-то странный учётный контейнер, который существует только потому, что планировщику нужно было куда-то девать счета? И как только вы начинаете задавать эти вопросы, то, что выглядит как простой спидометр, начинает больше походить на криминалистическую бухгалтерию», — объяснил Пламмер.

По его словам, диспетчер задач работает по таймеру, то есть он периодически обновляется, чтобы показать актуальную цифру. Это показывает, что машина отображает интерпретацию того, что произошло с ПК между каждым обновлением, а не реальное представление фактического использования процессора. Простым решением было бы разделить использование процессора на время, прошедшее между обновлениями, но Пламмер говорит, что это зависит от точности срабатывания таймера графического интерфейса. Он сравнил это с «доверием к метроному, который будет идеально ровным, пока едет по ухабистой грунтовой дороге, полной выбоин». 

Вместо этого он запрограммировал диспетчер задач так, чтобы тот запрашивал общее время каждого процесса с момента его запуска, то есть сумму времени ядра и пользовательского. Затем он вычитает из этого значения последнее общее время, полученное во время последнего обновления от этого конкретного процесса, чтобы получить потребление ЦП за этот период. Затем это число делится на общее время ЦП, учтенное и потреблённое всеми процессами между обновлениями. Хотя это может показаться сложнее, чем простое деление общего использования ЦП на время, прошедшее между обновлениями, работает гораздо точнее, говорит инженер.

Однако технологические достижения сделали это решение неточным. Поскольку учёт представляет собой лишь среднее значение между состояниями обновления, он не учитывает фактическую работу, происходящую в конкретный момент времени. «Современная загрузка ЦП больше похожа на загруженность автострады, чем на фактическое пройденное расстояние. На наполовину заполненной автостраде, где ездят Ferrari, может проехать гораздо больше машин, чем на забитой старыми цементовозами. Старый диспетчер задач был создан в эпоху, когда время, затраченное на работу, было довольно точным показателем выполненной работы. Но на современных процессорах с динамическим масштабированием частоты, турбонаддувом, термическим дросселированием и глубокими состояниями простоя эта связь стала гораздо слабее. Поэтому, когда цифры кажутся немного неточными, это не столько потому, что инструмент сломан, сколько потому, что аппаратное обеспечение перестало быть достаточно простым, чтобы один процент мог рассказать вам всю историю», — продолжил Пламмер. 

Он также добавил замечание: «Если бы я был королём… загрузка ЦП должна быть мерой объёма выполненной работы по сравнению с теоретическим максимальным объёмом работы, который МОГ БЫ быть выполнен». 

Ранее Пламмер протестировал в своей лаборатории 25 компьютеров, выпущенных с 1976 по 2023 год. Он использовал бенчмарк Dhrystone 2.2. В ходе теста современный Mac Pro на чипе Apple M2 Ultra оказался быстрее ПК 70-х годов PDP-11/34 примерно в 200 тысяч раз. По словам Пламмера, разница могла быть и больше, если бы код использованного им бенчмарка не был однопоточным.

ссылка на оригинал статьи https://habr.com/ru/articles/1026480/