Например, если у нас есть два std::atomic
с, и мы хотим сначала прочитать значение, а затем указать второе, что нам больше не нужно значение first.Мы не хотим, чтобы эти операции переупорядочивались (в противном случае первое значение может быть переписано до того, как мы его прочитаем), но между операциями нет зависимости данных, поэтому нам определенно нужен барьер для предотвращения переупорядочения (а memory_order_consume
не подходит).
Полный забор здесь, конечно, излишний.Также нам не нужно ни освобождать, ни приобретать семантику (даже если они обеспечивают такой барьер).Все, что нам нужно, это просто сохранить порядок операций чтения и записи.
Есть ли какой-нибудь дешевый забор, который делает то, что нам нужно?
РЕДАКТИРОВАТЬ: примеры того, что мне нужно.
std::atomic<X> atomicVal;
std::atomic<bool> atomicFlag = false;
...
auto value = atomicVal.load(std::memory_order_relaxed);
some_appropriative_fence();
atomicFlag.store(true, std::memory_order_relaxed);
И после того, как atomicFlag
установлено, atomicVal
может быть перезаписано на какое-то дополнительное значение, поэтому нам нужно прочитать его до.
Конечно, мы можем сделать
auto value = atomicVal.load(std::memory_order_relaxed);
std::atomic_thread_fence(std::memory_order_seq_cst);
atomicFlag.store(true, std::memory_order_relaxed);
но это будет слишком дорого для работы, в которой мы нуждаемся.
Мне интересно, какой минимальный забор достаточен, чтобы гарантировать порядок операций.