Поскольку я новичок в 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
Мобильная версия