这几天在写aio + epoll 代码,使用aio必须要字节对齐,因此需要用到posix_memalign()这个类似malloc()、alloc()等开辟内存的函数,函数原型:
int posix_memalign (void **memptr,
size_t alignment,
size_t size);
posix_memalign( )成功时会返回size字节的动态内存,并且这块内存的地址是alignment的倍数。但是由于我操作失误,posix_memalign(&buf[i], 521, 1024);程序还没有报错,表示申请成功的,最后free就爆炸。下面的测试代码(和aio+epoll代码中的情况一样)
用valgrind,gdb调试半天,posix_memalign()函数的资料查了半天,
还是找不出原因,最后绝望的时候一瞥,泥煤呀,下意识的512直接写成521。
结论:
1. posix_memalign()这个函数有缺陷,按照道理size不能整除alignment 或者 alignment不是2的幂就应该报错啊,而不是还给你申请成功,最后还可以使用,只不过free就爆炸。
2. 作为程序猿,不好好记住512,下意识的直接在测试代码中写521,也是醉了,而且还是连续两次写521。