What is stdatomic in C?

I was watching a talk yesterday about Go’s sync/atomic package which provides atomic operations like AddInt32(*int32, int32). These are implemented using special atomic CPU instructions.

I wondered what the equivalent is in C. The equivalent is stdatomic, which provides operations like atomic_fetch_add(atomic_int*, int). Here’s an example:

#include <stdio.h>
#include <stdatomic.h>
#include <pthread.h>

int cnt;
atomic_int acnt;

void* f(void* param) {
  for(int n = 0; n < 1000; ++n) {
    ++cnt;
    atomic_fetch_add(&acnt, 1);
  }
  return NULL;
}

int main(void) {
  pthread_t t[10];
  for (int i = 0; i < 10; i++) pthread_create(&t[i], NULL, f, NULL);
  for (int i = 0; i < 10; i++) pthread_join(t[i], NULL);
  printf("acnt = %u; cnt = %u;\n", acnt, cnt);
}
$ clang atomic_test.c
$ ./a.out
acnt = 10000; cnt = 7442;

Actually, I lied about the type signature of atomic_fetch_add. Its full signature is:

C atomic_fetch_add(volatile A* obj, M arg);
C atomic_fetch_add_explicit(volatile A* obj, M arg, memory_order order);

There are multiple things in here I don’t understand properly:

Tagged .
👋 I'm Jim, a full-stack product engineer. Want to build an amazing product and a profitable business? Read more about me or Get in touch!

More by Jim

This page copyright James Fisher 2017. Content is not associated with my employer. Found an error? Edit this page.