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

该博客讨论了在x86-64系统上创建一个线程安全的计数器类,使用_interlockedincrement函数确保原子性。作者关注的是_m_count变量的内存对齐以及如何避免使用_volatile关键字。文章指出,堆分配已经处理了内存对齐,因此不需要额外的对齐操作,并且建议在不能使用_volatile的情况下,仍然可以实现线程安全的计数器。
摘要由CSDN通过智能技术生成

这段代码似乎有用,但我是否正确使用了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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值