acl/lib_acl/include/stdlib/acl_atomic.h

102 lines
3.2 KiB
C

#ifndef ACL_ATOMIC_INCLUDE_H
#define ACL_ATOMIC_INCLUDE_H
#ifdef __cplusplus
extern "C"
{
#endif
#include "acl_define.h"
typedef struct ACL_ATOMIC ACL_ATOMIC;
/**
* 创建原子对象
* @return {ACL_ATOMIC*} 返回新创建的对象
*/
ACL_API ACL_ATOMIC *acl_atomic_new(void);
/**
* 释放原子对象
* @param self {ACL_ATOMIC*} 原子对象
*/
ACL_API void acl_atomic_free(ACL_ATOMIC *self);
/**
* 将指定对象与原子对象绑定,以便于对该对象进行原子操作
* @param self {ACL_ATOMIC*} 原子对象
* @param value {void*} 被操作的对象,通过原子对象实现对该对象的原子操作
*/
ACL_API void acl_atomic_set(ACL_ATOMIC *self, void *value);
/**
* 比较并交换对象,当原子对象绑定的对象与给定比较对象相同时才设置新对象且
* 返回之前绑定的对象
* @param self {ACL_ATOMIC*} 原子对象
* @param cmp {void*} 待比较对象指针
* @param value {void*} 当原子对象与待比较对象相同时会将该对象与原子对象绑定
* @return {void*} 返回原子对象之前绑定的对象
*/
ACL_API void *acl_atomic_cas(ACL_ATOMIC *self, void *cmp, void *value);
/**
* 将原子对象与新对象进行绑定,并返回之前绑定的对象
* @param self {ACL_ATOMIC*} 原子对象
* @param value {void*} 将被绑定的新对象
* @return {void*} 返回之前绑定的对象
*/
ACL_API void *acl_atomic_xchg(ACL_ATOMIC *self, void *value);
/**
* 当调用 acl_atomic_set 绑定的对象为数值对象时,可以调用此函数设置被绑定对象
* 的长整数值
* @param self {ACL_ATOMIC*} 原子对象
* @param n {long long} 被原子对象所绑定的对象将被赋值为此值
*/
ACL_API void acl_atomic_int64_set(ACL_ATOMIC *self, long long n);
/**
* 先获得数值对象所存储的整数值,然后再增加指定的值存储于该数值对象中
* @param self {ACL_ATOMIC*} 原子对象
* @param n {long long} 增加值
* @return {long long} 返回增加之前数据数值对象的值
*/
ACL_API long long acl_atomic_int64_fetch_add(ACL_ATOMIC *self, long long n);
/**
* 对数据对象存储的值增加指定的值,并返回结果值
* @param self {ACL_ATOMIC*} 原子对象
* @param n {long long} 增加值
* @return {long long} 返回增加之后的值
*/
ACL_API long long acl_atomic_int64_add_fetch(ACL_ATOMIC *self, long long n);
/**
* 比较并交换整数值,当原子对象存储的整数值与给定比较整数值相同时才设置新整数
* 值且返回之前存储的整数值
* @param self {ACL_ATOMIC*} 原子对象
* @param cmp {long long} 待比较整数值
* @param n {long long} 当原子对象与待比较整数值相同时会将原子对象设置为此值
* @return {long long} 返回原子对象之前存储的整数值
*/
ACL_API long long acl_atomic_int64_cas(ACL_ATOMIC *self, long long cmp, long long n);
/****************************************************************************/
typedef struct ACL_ATOMIC_CLOCK ACL_ATOMIC_CLOCK;
ACL_API ACL_ATOMIC_CLOCK *acl_atomic_clock_alloc(void);
ACL_API void acl_atomic_clock_free(ACL_ATOMIC_CLOCK *clk);
ACL_API long long acl_atomic_clock_count_add(ACL_ATOMIC_CLOCK *clk, int n);
ACL_API long long acl_atomic_clock_users_add(ACL_ATOMIC_CLOCK *clk, int n);
ACL_API void acl_atomic_clock_users_count_inc(ACL_ATOMIC_CLOCK *clk);
ACL_API long long acl_atomic_clock_count(ACL_ATOMIC_CLOCK *clk);
ACL_API long long acl_atomic_clock_atime(ACL_ATOMIC_CLOCK *clk);
ACL_API long long acl_atomic_clock_users(ACL_ATOMIC_CLOCK *clk);
#ifdef __cplusplus
}
#endif
#endif