Получение общего процента загрузки процессора в Windows с помощью C++C++

Программы на C++. Форум разработчиков
Ответить
Anonymous
 Получение общего процента загрузки процессора в Windows с помощью C++

Сообщение Anonymous »

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

Может быть, я упускаю суть, но, похоже, популярный способ выяснить это — запросить процессор два раза с интервалом не менее 200 мс между каждой проверкой, чтобы избежать проблем с чем-то, называемым... разрешением? Так да! Как, черт возьми, мне это сделать? :( У меня синтаксические проблемы D:

Я поделюсь своим исходным кодом, чтобы вы могли увидеть, что именно. До сих пор я это делал. Это все в одном .cpp, я использую VS2013 Express для C++, и он предназначен только для Windows для многоядерных процессоров.

Предупреждаем заранее: мне очень жаль за все комментарии в коде :x Кроме того, если вы скопируете этот код и запустите его, он сгенерирует ошибку. Файл .CSV с именем log.CSV

//included libraries/functionality for input/output
#include
#include
#include
using namespace std;

//creates a static variable to convert Bytes to Megabytes
#define MB 1048576

//main program code loop
int main()
{
//Code block intiialization for the memory referenced in the Kernell
MEMORYSTATUSEX memStat;
memStat.dwLength = sizeof (memStat);
GlobalMemoryStatusEx(&memStat);

//loads the SYSTEMTIME
SYSTEMTIME sysTime;
//Retrieves data so that we have a way to Get it to output when using the pointers
GetSystemTime(&sysTime);

//setting the I/O for our log file to be "myfile"
ofstream myfile;
// ios::out means that we're outputting data to the file
// ios::app means that all the data we're outputting goes to the end of that log file instead of the start
myfile.open("log.csv", ios::out | ios::app);

//a while loop that gathers and logs data every quarter of a second to gather 4 data points in one second
int counter = 0;
while (counter < 4)
{
//Timestamp + Memory Info, and eventually CPU Load percentage
myfile

Подробнее здесь: https://stackoverflow.com/questions/231 ... ows-with-c
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C++»