c语言increment函数怎么用,c – 如何从堆中为InterlockedIncrement函数分配正确的内存对齐?...

这段代码似乎有用,但我是否正确使用了InterlockedIncrement函数? m_count的正确内存对齐是我主要关心的问题.假设我们在x86-64系统上并编译一个64位应用程序(如果重要的话).顺便说一句,为了我的实际目的,我不能将m_count声明为volatile long,然后使用InterlockedIncrement(& m_count);但它必须是指向堆中数据的指针.

#include

#include

class ThreadSafeCounter {

public:

ThreadSafeCounter()

{

// Are those arguments for size and alignment correct?

void* placement = _aligned_malloc( sizeof(long), sizeof(long) );

m_count = new (placement) long(0);

}

~ThreadSafeCounter()

{

_aligned_free( const_cast(m_count) );

}

void AddOne()

{

InterlockedIncrement(m_count);

}

long GetCount()

{

return *m_count;

}

private:

volatile long* m_count;

};

解决方法:

堆分配器已将返回的地址与本机平台字大小对齐. x86为4个字节,x64为8个字节.您在任一平台上使用32位长MSVC.无需跳过_aligned_malloc()箍.

标签:c,multithreading,memory-alignment,thread-safety,heap

来源: https://codeday.me/bug/20190723/1517465.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值