posix_memalign函数详解

前言

在编写可移植的代码的时候,所有的类型都该自然对齐,因为不对齐会导致性能下降,在大多数情况下,编译器和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);
}

推荐一个零声学院免费教程,个人觉得老师讲得不错,
分享给大家:[Linux,Nginx,ZeroMQ,MySQL,Redis,
fastdfs,MongoDB,ZK,流媒体,CDN,P2P,K8S,Docker,
TCP/IP,协程,DPDK等技术内容,点击立即学习:

猜你喜欢

转载自blog.csdn.net/weixin_46935110/article/details/130792424