13

I'd like to document what high-level (i.e. C++ not inline assembler ) functions or macros are available for Compare And Swap (CAS) atomic primitives...

E.g., WIN32 on x86 has a family of functions _InterlockedCompareExchange in the <_intrin.h> header.

C. K. Young
  • 219,335
  • 46
  • 382
  • 435
oz10
  • 153,307
  • 27
  • 93
  • 128

7 Answers7

17

I'll let others list the various platform-specific APIs, but for future reference in C++09 you'll get the

atomic_compare_exchange() 

operation in the new "Atomic operations library".

Michael Burr
  • 333,147
  • 50
  • 533
  • 760
9

glib, a common system library on Linux and Unix systems (but also supported on Windows and Mac OS X), defines several atomic operations, including g_atomic_int_compare_and_exchange and g_atomic_pointer_compare_and_exchange.

Ben Combee
  • 16,831
  • 6
  • 41
  • 42
6

GCC has some built-ins for atomic accesses, too.

Randall Cook
  • 6,728
  • 6
  • 33
  • 68
C. K. Young
  • 219,335
  • 46
  • 382
  • 435
2

On Solaris there is "atomic.h" (i.e. <sys/atomic.h>).

Christian.K
  • 47,778
  • 10
  • 99
  • 143
2

MacOS X has OSAtomic.h

Don Neufeld
  • 22,720
  • 11
  • 51
  • 50
2

There have been a series of working group papers on this subject proposing changes to the C++ Standard Library. WG N2427 (C++ Atomic Types and Operations) is the most recent, which contributes to section 29 -- Atomic operations library -- of the pending standard.

seh
  • 14,999
  • 2
  • 48
  • 58
1

java has this CAS operation, too

see here

there are practical uses for this, like a lock-free hashtable used in multiprocessor system

Andreas Petersson
  • 16,248
  • 11
  • 59
  • 91