Android的NDK下原子操作函数的应用

在尝试使用NDK实现多线程智能指针时,发现无法直接使用内核原子操作函数。通过查阅文档,了解到Android在sys/atomics.h中提供了简单的原子操作,包括自加、自减、赋值和比较赋值。文章介绍了这些操作的用法,并提到了__sync_val_compare_and_swap函数的工作原理。同时,还分享了两篇关于Linux原子操作的参考资料链接。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 最近想用NDK实现一个多线程版的智能指针自己用,结果发现在NDK应用层无法使用内核类的原子操作函数~也无法去指定对应的CPU去调用Linux原子操作函数,毕竟手机的cpu千奇百怪。。。

 最后查了半天文档发现原来在sys/atomics.h中,简单定义了一些原子操作,文档见 ANDROID ATOMICS OPERATIONS


1. 自加操作

__ATOMIC_INLINE__ int
__atomic_inc(volatile int *ptr)
{
  return __sync_fetch_and_add (ptr, 1);
}
将ptr指向的值加一,返回原来的值,我的时NDKR9 他自己调用了linux的原子函数。。。

2. 自减操作

__ATOMIC_INLINE__ int
__atomic_dec(volatile int *ptr)
{
  return __sync_fetch_and_sub (ptr, 1);
}

同上相当于i-- ,再次吐槽他自己调linux函数。。。

3. 赋值

__ATOMIC_INLINE__ int
__atomic_swap(int _new, volatile int *ptr)
{
    int prev;
    do {
        prev = *ptr;
    } while (__sync_val_compare_and_swap(ptr, prev, _new) != prev);
    return prev;
}
将 _new 的值赋给指向的地址,do{}while是为了防止当赋值操作结束后ptr指向的值再次变化,

实际上调用的Linux上的比较赋值。。。

4. 比较赋值

__ATOMIC_INLINE__ int
__atomic_cmpxchg(int old, int _new, volatile int *ptr)
{
    /* We must return 0 on success */
    return __sync_val_compare_and_swap(ptr, old, _new) != old;
}

__sync_val_compare_and_swap 函数的意思是, 当 *ptr == old 时 *ptr = _new 函数的返回值一定是ptr的原值,所以__atomic_cmpxchg函数的返回值为 当 *ptr == old 时 返回0 否则返回 1 


另附上一个讲解Linux原子操作的文章

http://wenku.baidu.com/link?url=u7gKXq19s2Wq-pOHNF0QvrClQBEsUNEhK60iNaGjwZqei787vdbh7L96OyUpZuRZspu_xPRN9AI2Zv4op-a09kB-iFbf0otYgZP8XxeRswG

http://blog.youkuaiyun.com/dlite/article/details/5952174

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值