gcc (GCC) 4.6.0 20110419 (Red Hat 4.6.0-5)
Я пытаюсь узнать время начала и окончания.И получите разницу между ними.
У меня есть функция для создания API для нашего существующего оборудования.
API wait_events принимает один аргумент - время в миллисекундах.Так что я пытаюсь получить начало до цикла пока.И используя время, чтобы получить количество секунд.Затем после 1 итерации цикла получите разницу во времени, а затем сравните эту разницу с временем ожидания.
Большое спасибо за любые предложения,
/* Wait for an event up to a specified time out.
* If an event occurs before the time out return 0
* If an event timeouts out before an event return -1 */
int wait_events(int timeout_ms)
{
time_t start = 0;
time_t end = 0;
double time_diff = 0;
/* convert to seconds */
int timeout = timeout_ms / 100;
/* Get the initial time */
start = time(NULL);
while(TRUE) {
if(open_device_flag == TRUE) {
device_evt.event_id = EVENT_DEV_OPEN;
return TRUE;
}
/* Get the end time after each iteration */
end = time(NULL);
/* Get the difference between times */
time_diff = difftime(start, end);
if(time_diff > timeout) {
/* timed out before getting an event */
return FALSE;
}
}
}
Функция, которая будет вызываться, будет выглядеть следующим образом.
int main(void)
{
#define TIMEOUT 500 /* 1/2 sec */
while(TRUE) {
if(wait_events(TIMEOUT) != 0) {
/* Process incoming event */
printf("Event fired\n");
}
else {
printf("Event timed out\n");
}
}
return 0;
}
=============== РЕДАКТИРОВАТЬ с обновленными результатами ==================
1) With no sleep -> 99.7% - 100% CPU
2) Setting usleep(10) -> 25% CPU
3) Setting usleep(100) -> 13% CPU
3) Setting usleep(1000) -> 2.6% CPU
4) Setting usleep(10000) -> 0.3 - 0.7% CPU