std::malloc

来自cppreference.com
< cpp‎ | memory‎ | c
 
 
工具库
通用工具
格式化库 (C++20)
(C++11)
关系运算符 (C++20 中弃用)
整数比较函数
(C++20)(C++20)(C++20)
(C++20)
swap 与类型运算
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
常用词汇类型
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)

初等字符串转换
(C++17)
(C++17)
栈踪
 
动态内存管理
智能指针
(C++11)
(C++11)
(C++11)
(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 前)
(C++11)(C++23 前)
杂项
(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 表达式

对于加载大文件,经由如 POSIX 上的 mmap 或 Windows 上的 CreateFileMapping(A/W) 伴随 MapViewOfFile 的操作系统特定函数进行文件映射,比为文件读取分配缓冲区更适合。

示例

#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 中移除)
获得未初始化存储
(函数模板)