Я пытаюсь внедрить «круговой очередь без блокировки», используя Atomics и Memory_orders. Помогите в просмотре CODEC CODEC++

Программы на C++. Форум разработчиков
Ответить
Anonymous
 Я пытаюсь внедрить «круговой очередь без блокировки», используя Atomics и Memory_orders. Помогите в просмотре CODEC CODE

Сообщение Anonymous »

Поскольку я новичок в Memory_order, я не уверен, что я переполняю свою реализацию, используя слишком много заказов памяти. Я делюсь своим кодом для чтения данных из очереди. Может ли кто -нибудь просмотреть его и предоставить комментарии? Я чувствую, что могу переусердствовать. std::atomic_size_t _read_index;
std::atomic_size_t _write_index;
std::atomic_bool _empty;
std::vector* _queue;

// function:
inline T* read() {

size_t idx = _read_index.load(std::memory_order_acquire);
T* result = nullptr;

if ((idx != _write_index.load(std::memory_order_relaxed)) || !_empty.load(std::memory_order_relaxed)) {

result = &*_queue[idx];

idx = (idx + 1) % _queue->size();
_empty.store(idx == _write_index.load(), std::memory_order_release);
_read_index.store(idx, std::memory_order_release);
}

return result;
}


Подробнее здесь: https://stackoverflow.com/questions/795 ... -memory-or
Ответить

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

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

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

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

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