malloc提供的低阶位保证是什么?

前端之家收集整理的这篇文章主要介绍了malloc提供的低阶位保证是什么?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
当你调用C的malloc时,是否可以保证前几个低阶位是什么?如果您正在为动态语言编写编译器/解释器,但希望使用bbbbbbbb bbbbbbbb形式的fixnums. . . bbbbbbb1(其中b有点)和bbbbbbbb bbbbbbbb形式的指针. . . bbbbbbb0(反之亦然),有没有办法保证malloc会返回符合这种方案的指针?

我应该只分配比我需要的多两个字节,如果需要,将返回值递增1以适应位方案,并将malloc返回的实际指针存储在第二个字节中,以便我知道要释放什么?

我可以假设malloc将返回一个零指针作为最后一位吗?我可以假设x86末尾有两个零位,而x64末尾有四个零位吗?

解决方法

只要指针针对所有可能的类型对齐,C不保证低阶位为零.实际上,最低位的2或3可能为零,但不要指望它.

您可以自己确保,但更好的方法是使用像posix_memalign这样的东西.

如果你想自己做,你需要分配内存并跟踪原始指针.类似的东西(假设您需要16字节对齐,可以是通用的,未经测试):

void* my_aligned_malloc16(size_t sz) {
   void* p = malloc(sz + 15 + 16); // 15 to ensure alignment,16 for payload
   if (!p) return NULL;
   size_t aligned_addr = ((size_t)p + 15) & (~15);
   void* aligned_ptr = (void*) aligned_addr;
   memcpy(aligned_ptr,&p,sizeof(void*)); // save original pointer as payload
   return (void*)(aligned_addr + 16); // return aligned address past payload
}

void my_aligned_free16(void* ptr){ 
   void** original_pointer = (void**)( ((size_t)ptr) - 16 );
   free(*original_pointer);  
}

正如你所看到的那样相当丑陋,所以更喜欢使用像posix_memalign这样的东西.您的运行时可能具有类似的功能,如果该运行时不可用,例如使用MSVC时memalign(感谢@R ..)或_aligned_malloc.

猜你在找的C&C++相关文章