Реализация таймера для небольшой корневой кучиLinux

Ответить
Anonymous
 Реализация таймера для небольшой корневой кучи

Сообщение Anonymous »

Используйте список для хранения информации о таймере и сортируйте его от меньшего к большему в зависимости от времени, указанного в информации о таймере. Выберите первый элемент с наименьшим временем синхронизации в качестве времени синхронизации для основного таймера. В обратном вызове измените порядок списка, чтобы выбрать новое время синхронизации. То есть каждый поток имеет только один основной таймер, но в списке хранится множество информации о таймерах. Затем необходимо, чтобы обратный вызов находился в том же потоке, что и этот основной таймер. Поскольку поток, в котором расположен таймер, находится в том же потоке, что и функция обработки сигнала, которая выполняет обратный вызов после истечения срока действия, будет выполнена операция сброса таймера SetTimer. в функции обработки сигналов, и каждый раз он будет зависать в timer_create, но другие потоки в порядке и не затрагиваются。

Код: Выделить всё

bool posixThreadTimerEx::SetTimer(INT_64 nElapse)
{
if (nElapse 

Подробнее здесь: [url]https://stackoverflow.com/questions/79139829/implementation-of-timer-for-small-root-heap[/url]
Ответить

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

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

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

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

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