1. Можно узнать "чистое" время выполнения процеса? Тоесть сколько времени выполнялся процесс с точностью до сотых секунды. Вариант
QTime timer;
timer.start();
QProcess pi;
pi.start("c:\\1.exe");
pi.waitForFinished();
qDebug("Process time: %d\n", timer.elapsed());
не подходит тк при низкой загруженности выходит в среднем: 1610 мсек. А если загрузить ЦП на 10-15% уже 1719 мсек. А в моем случае результаты могу отличиться МАХ на 40-50 мсек. Когда-то в визуалке я делал подобное так:
FILETIME KernelTime, UserTime;
union {
LONGLONG li;
FILETIME ft;
} CreateTime, ExitTime, ElapsedTime;
SYSTEMTIME ElTiSys, UsTiSys, KeTiSys;
...
if(GetProcessTimes(pi.hProcess, &CreateTime.ft, &ExitTime.ft, &KernelTime, &UserTime)) {
FileTimeToSystemTime(&UserTime, &UsTiSys);
f_execute_time = UsTiSys.wSecond + ((float)(UsTiSys.wMilliseconds) / 1000);
}
2. И еще момент, можно ограничить функционал выполняемой программы? То есть запретить ей некоторые действия, запись в файл использование портов и тд... Перехват WinAPI подойдёт но я так и не нашел нормального примера или статьи по перехвату.
Пишу в QDevelop, Qt 4.3.3 под winxp