Я реализовал два процесса с одним потоком A & B с двумя очередями msg [отдельная очередь для отправки и получения]. Процесс A отправит сообщение в B и ждет ответа в очереди приема.Какие часы следует использовать для взаимодействия между процессами в Linux?
Хочу послать временную метку из процесса А для обработки B. Если процесс В принимает сообщение после того, как 10 секунд, я хочу, чтобы отправить строку ошибки от процесса B к A.
Точность должна быть в миллисекунды.
В процессе А я использовал,
struct timespec msg_dispatch_time;
clock_gettime(CLOCK_REALTIME, &msg_dispatch_time);
:
:
add_timestamp_in_msg(msg, msg_dispatch_time);
:
if (msgsnd(msqid, msg, sizeof(msg), msgflg) == -1)
perror("msgop: msgsnd failed");
В процессе B,
struct timespec msg_dispatch_time;
struct timespec msg_receive_time;
:
clock_gettime(CLOCK_REALTIME, &msg_received_time);
:
if(!(time_diff(msg_received_time, msg_dispatch_time) >= 10))
msgsnd(msqid, &sbuf, buf_length, msg_flag)
else
{
/*send the error string.*/
//msgsnd(msgid,)
}
Мой вопрос,
1) Как написать функцию time_diff здесь с точностью до миллисекунды, чтобы сравнить против 10 секунд?
if(!(time_diff(msg_received_time, msg_dispatch_time) >= 10))
/********Existing time diff code******************/
long int time_diff (struct timeval time1, struct timeval time2)
{
struct timeval diff,
if (time1.tv_usec < time2.tv_usec) {
time1.tv_usec += 1000000;
time1.tv_sec--;
}
diff.tv_usec = time1.tv_usec - time2.tv_usec;
diff.tv_sec = time1.tv_sec - time2.tv_sec;
return diff.tv_sec; //return the diff in second
}
2) Является ли clock_gettime прекрасным для использования в процессе в одной системе?
'enum {NS_PER_SECOND = 1000000000}; void sub_timespec (struct timespec t1, struct timespec t2, struct timespec * td) { td-> tv_nsec = t2.tv_nsec - t1.tv_nsec; td-> tv_sec = t2.tv_sec - t1.tv_sec; if (td-> tv_sec> 0 && td-> tv_nsec <0) { td-> tv_nsec + = NS_PER_SECOND; td-> tv_sec--; } else if (td-> tv_sec < 0 && td-> tv_nsec> 0) {td-> tv_nsec - = NS_PER_SECOND; td-> tv_seC++; } } '' –
Проверка timeval_subtract' в http://www.gnu.org/software/libc/manual/html_node/Elapsed-Time.html – PnotNP
@NulledPointer: 'timeval_subtract()' для 'STRUCT timeval' а чем 'struct timespec', не так ли? Но концепции, безусловно, могут быть применены к другому типу. –