关于posix_memalign( )函数的坑

            这几天在写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代码中的情况一样)

关于posix_memalign( )函数的坑_第1张图片


用valgrind,gdb调试半天,posix_memalign()函数的资料查了半天,

关于posix_memalign( )函数的坑_第2张图片


还是找不出原因,最后绝望的时候一瞥,泥煤呀,下意识的512直接写成521。



结论:

  1. posix_memalign()这个函数有缺陷,按照道理size不能整除alignment 或者 alignment不是2的幂就应该报错啊,而不是还给你申请成功,最后还可以使用,只不过free就爆炸。

  2. 作为程序猿,不好好记住512,下意识的直接在测试代码中写521,也是醉了,而且还是连续两次写521。




    

你可能感兴趣的:(经验积累)