cacheline 优化

今天看rockdb的代码, 看到整个程序在分配内存和释放的内存的时候,并不是直接用的malloc 或者 new 等,而是使用cacheline_aligned_alloc,了解了一下相关原理,内存load到缓存的时候 ,是按照cacheline大小load到缓存的,所以进行分配内存的时候,尽量按照cacheline大小进行分配,这样访问一个结构体就是访问一个cacheline,这些细节可以使得程序可能更快吧。把代码贴上,以后分配内存直接用这个代码分配。


void *cacheline_aligned_alloc(size_t size) {
#if __GNUC__ < 5 && defined(__SANITIZE_ADDRESS__)
  return malloc(size);
#elif ( _POSIX_C_SOURCE >= 200112L || _XOPEN_SOURCE >= 600 || defined(__APPLE__))
  void *m;
  errno = posix_memalign(&m, CACHE_LINE_SIZE, size);
  return errno ? nullptr : m;
#else
  return malloc(size);
#endif
}


void cacheline_aligned_free(void *memblock) {
  free(memblock);
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值