_aligned_malloc自己实现

本文将详细讲解如何实现-aligned_malloc,通过引用《Hacker's Delight》这本书,揭示计算机运算的秘密,适合编译器开发者、库开发者和反工程爱好者。书中介绍了不为人知的二进制编码技巧和底层算法,内容深入且实用。
摘要由CSDN通过智能技术生成


void* aligned_malloc(size_t size, size_t align)
{
	void* raw_malloc_ptr;		//初始分配的地址
	void* aligned_ptr;			//最终我们获得的alignment地址
	
	if( align & (align - 1) )	//如果alignment不是2的n次方,返回
	{
		errno = EINVAL;
		return ( (void*)0 );
	}
	
	if( 0 == size )
	{
		return ( (void*)0 );
	} 
	
	//将alignment置为至少为2*sizeof(void*),一种优化做法。
	if( align < 2*sizeof(void*) )
	{
		align = 2 * sizeof(void*);
	}
	
	raw_malloc_ptr = malloc(size + align);
	if( !raw_malloc_ptr )
	{
		return ( (void*)0 );
	}
	
	//Align  We have at least sizeof (void *) space below malloc'd ptr. 
	aligned_ptr = (void*) ( ((size_t)raw_malloc_ptr + align) & ~((size_t)align - 1));
	
	( (void**)aligned_ptr )[-1] = raw_malloc_ptr;
	
	return aligned_ptr;
}

void* aligned_free(void * aligned_ptr)
{
	if( aligned_ptr )
	{
		free( ((void**)aligned_ptr)[-1] );
	}
}
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值