std::malloc

来自cppreference.com
< cpp‎ | memory‎ | c
 
 
 
动态内存管理
未初始化存储
(C++17)
垃圾收集支持
杂项
(C++20)
(C++11)
(C++11)
C 库
malloc
低层内存管理
 
定义于头文件 <cstdlib>
void* malloc( std::size_t size );

分配 size 字节的未初始化存储。

若分配成功,则返回指向分配的适合对任何标量类型对齐的内存块中,最低(首)字节的指针。

size 为零,则行为是实现定义的(可以返回空指针,或某个不可用于访问存储,但必须传递给 std::free 的非空指针)。

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

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

(C++11 起)

参数

size - 要分配的字节数

返回值

成功时,返回指向新分配内存起始的指针。返回的指针必须用 std::free()std::realloc() 解分配。

失败时,返回空指针。

注意

任何情况下,此函数不调用构造函数或初始化内存。无能保证调用匹配的解分配函数的预备使用的智能指针。 C++ 中偏好的内存分配方法是用 RAII 预备函数 std::make_uniquestd::make_shared 、容器构造函数等,而在低层代码中为 new 表达式

示例

#include <iostream>   
#include <cstdlib> 
#include <string>
 
int main() 
{
    // 为 4 个 string 的数组分配足够空间
    if(auto p = (std::string*)std::malloc(4 * sizeof(std::string)))
    {
        int i = 0;
        try
        {
            for(; i != 4; ++i) // 填充数组
                new(p + i) std::string(5, 'a' + i);
 
            for(int j = 0; j != 4; ++j) // 打印出来
                std::cout << "p[" << j << "] == " << p[j] << '\n';
        }
        catch(...) {}
 
        for(; i != 0; --i) // 清理
            p[i - 1].~basic_string();
 
        std::free(p);
    }
}

输出:

p[0] == aaaaa
p[1] == bbbbb
p[2] == ccccc
p[3] == ddddd

参阅

分配函数
(函数)
(C++17 中弃用)(C++20 中移除)
获得未初始化存储
(函数模板)