Name

atomic<T> Template Class — Template class for atomic operations.

Synopsis

#include "tbb/atomic.h"

template<typename T> atomic;

Description

An atomic<T> supports atomic read, write, fetch-and-add, fetch-and-store, and compare-and-swap. Type T may be an integral type or a pointer type. When T is a pointer type, arithmetic operations are interpreted as pointer arithmetic. For example, if x has type atomic<float*> and a float occupies four bytes, ++x advances x by four bytes. The specialization atomic<void*> does not allow pointer arithmetic.

Some of the methods offer two method variants, one of which is a templated form that permits more selective memory fencing using memory_semantics. For instance, the first of the following fetch_and_add calls is templated to specify a release fence, whereas the second call is not templated:

	refcount.fetch_and_add<release>(-1);
	refcount.fetch_and_add(1);

On IA-32 and Intel 64 processors, the templated calls have the same effect as the nontemplated variants because the processors do not support weaker memory consistency. On processors with weak memory consistency, the templated calls may improve performance by allowing the memory subsystem more latitude on the orders of reads and writes; therefore, using them may improve performance. Table 7-5 shows the fencing defaults (nontemplated form).

Tip

The template class atomic<T> does not have any nontrivial constructors because such constructors could lead to accidental introduction of compiler temporaries ...

Get Intel Threading Building Blocks now with the O’Reilly learning platform.

O’Reilly members experience books, live events, courses curated by job role, and more from O’Reilly and nearly 200 top publishers.