如果我们有:
__int32 some_var = 0;
什么是最好的(如果有的话)调用方式InterlockedExchange
,InterlockedIncrement
以及其他需要LONG*
的联锁功能some_var
?
因为,在任何 Windows 上都可以保证LONG
32 位,所以通过(long*) some_var
. 但是,在我看来,这很丑陋,我无法确认它是安全的。
请注意,我无法将类型更改为,long
因为它不可移植。我正好需要 32 位类型。
更新:对提供可移植原子操作的库的一些研究表明,没有人会为转换而烦恼。一些例子:
typedef WINBASEAPI apr_uint32_t (WINAPI * apr_atomic_win32_ptr_val_fn)
(apr_uint32_t volatile *,
apr_uint32_t);
APR_DECLARE(apr_uint32_t) apr_atomic_add32(volatile apr_uint32_t *mem, apr_uint32_t val)
{
#if (defined(_M_IA64) || defined(_M_AMD64))
return InterlockedExchangeAdd(mem, val);
#elif defined(__MINGW32__)
return InterlockedExchangeAdd((long *)mem, val);
#else
return ((apr_atomic_win32_ptr_val_fn)InterlockedExchangeAdd)(mem, val);
#endif
}
原子操作:
AO_INLINE AO_t
AO_fetch_and_sub1_full (volatile AO_t *p)
{
return _InterlockedDecrement64((LONGLONG volatile *)p) + 1;
}