前言
在编写可移植的代码的时候,所有的类型都该自然对齐,因为不对齐会导致性能下降,在大多数情况下,编译器和C库透明地帮你处理对齐问题。POSIX 标明了通过malloc( ), calloc( ), 和 realloc( ) 返回的地址对于任何的C类型来说都是对齐的。
在Linux中,这些函数返回的地址在32位系统是以8字节为边界对齐,在64位系统是以16字节为边界对齐的。但是对于更大的边界,例如页面,程序员需要动态的对齐。因此,POSIX 1003.1d提供一个叫做posix_memalign( )的函数:
int posix_memalign (void **memptr, size_t alignment, size_t size);
注意
1、第二个参数size必须是alignment的 2 的整数幂次倍
2、对于这个函数,errno不会被设置,只能通过返回值得到,返回值为0表示内存申请成功
使用示例
posix_memalign成功时会返回10240(size)字节的动态内存,即memptr所指向的内存的地址,并且这块内存的地址是256(alignment)的倍数
int main () { char *memptr; int ret; ret = posix_memalign (&memptr, 256, 10240); if (ret) { fprintf (stderr, "posix_memalign: %s\n", strerror (ret)); return -1; } //释放所申请内存 free (buf); }