std::aligned_alloc

来自cppreference.com
< cpp‎ | memory‎ | c
 
 
工具库
语言支持
类型支持(基本类型、RTTI)
库功能特性测试宏 (C++20)
动态内存管理
程序工具
协程支持 (C++20)
变参数函数
调试支持
(C++26)
三路比较
(C++20)
(C++20)(C++20)(C++20)
(C++20)(C++20)(C++20)
通用工具
日期和时间
函数对象
格式化库 (C++20)
(C++11)
关系运算符 (C++20 中弃用)
整数比较函数
(C++20)(C++20)(C++20)   
(C++20)
交换类型运算
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
常用词汇类型
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
初等字符串转换
(C++17)
(C++17)

 
动态内存管理
未初始化内存算法
受约束的未初始化内存算法
分配器
垃圾收集器支持
(C++11)(C++23 前)
(C++11)(C++23 前)
(C++11)(C++23 前)
(C++11)(C++23 前)
(C++11)(C++23 前)
(C++11)(C++23 前)



 
在标头 <cstdlib> 定义
void* aligned_alloc( std::size_t alignment, std::size_t size );
(C++17 起)

分配 size 字节的未初始化存储,由 alignment 指定其对齐(在目标区域中隐式创建对象)。size 参数必须是 alignment 的整数倍。

要求下列函数是线程安全的:

对这些分配或解分配特定存储单元的函数调用以单独全序出现,而并且在此顺序中,每个解分配调用先发生于下个分配(如果存在)。

参数

alignment - 指定对齐。必须是实现支持的合法对齐。
size - 分配的字节数。alignment 的整数倍。

返回值

成功时,返回指向新分配内存起始的指针。为避免内存泄漏,返回的指针必须由 std::freestd::realloc 解分配。

失败时,返回空指针。

注解

传递不是 alignment 整数倍的 size 或不受实现支持或非法的 alignment 导致函数失败并返回空指针(C11 刚发布时,曾指定此情况为未定义行为,这为 DR 460 所纠正)。

作为“实现支持”要求的例子,POSIX 函数 posix_memalign 接受任何是二的幂且为 sizeof(void*) 倍数的 alignment,而基于 POSIX 的 aligned_alloc 实现继承此要求。

基础对齐始终得到支持。若 alignment 是二的幂且不大于 alignof(std::max_align_t),则 aligned_alloc 可以简单地调用 std::malloc

常规的 std::malloc 分配适用于具有任何基础对齐的对象类型的内存。此函数适用于过对齐分配,例如对 SSE、缓存线或 VM 页边界。

Microsoft C 运行时库不支持此函数,因为其 std::free 的实现无法处理任意种类的对齐分配。 MS CRT 提供 _aligned_malloc 作为替代(其结果应以 _aligned_free 释放)。

示例

#include <cstdio>
#include <cstdlib>
 
int main()
{
    int* p1 = static_cast<int*>(std::malloc(10*sizeof *p1));
    std::printf("默认对齐地址:      %p\n", static_cast<void*>(p1));
    std::free(p1);
 
    int* p2 = static_cast<int*>(std::aligned_alloc(1024, 10*sizeof *p2));
    std::printf("1024 字节对齐地址: %p\n", static_cast<void*>(p2));
    std::free(p2);
}

可能的输出:

默认对齐地址:      0x2221c20
1024 字节对齐地址: 0x2222400

参阅

(C++11)(C++23 中弃用)
定义适于用作给定大小的类型的未初始化存储的类型
(类模板)