std::malloc
来自cppreference.com
<tbody>
</tbody>
| 在标头 <cstdlib> 定义
|
||
void* malloc( std::size_t size ); |
||
分配 size 字节的未初始化存储。
若分配成功,则返回指向分配的适合对任何标量类型对齐(至少同 std::max_align_t 一样严格)的内存块(在目标区域中隐式创建对象)中,最低(首)字节的指针。
若 size 为零,则行为是实现定义的(可以返回空指针,或某个不可用于访问存储,但必须传递给 std::free 的非空指针)。
|
要求下列函数是线程安全的:
对这些分配或解分配特定存储单元的函数调用以单独全序出现,而并且在此顺序中,每个解分配调用先发生于下个分配(如果存在)。 |
(C++11 起) |
参数
| size | - | 要分配的字节数 |
返回值
成功时,返回指向新分配内存起始的指针。为避免内存泄漏,返回的指针必须用 std::free() 或 std::realloc() 解分配。
失败时,返回空指针。
注解
任何情况下,此函数不调用构造函数或初始化内存。没有可以直接使用的保证会调用匹配的解分配函数的智能指针。C++ 中偏好的内存分配方法是用 RAII 就绪的函数 std::make_unique、std::make_shared、容器构造函数等,而在低层代码中为 new 表达式。
对于加载大文件,经由如 POSIX 上的 mmap 或 Windows 上的 CreateFileMapping(A/W) 伴随 MapViewOfFile 的操作系统特定函数进行文件映射,比为文件读取分配缓冲区更适合。
示例
运行此代码
#include <cstdlib>
#include <iostream>
#include <memory>
#include <string>
int main()
{
constexpr std::size_t size = 4;
if (auto ptr = reinterpret_cast<std::string*>(std::malloc(size * sizeof(std::string))))
{
try
{
for (std::size_t i = 0; i < size; ++i)
std::construct_at(ptr + i, 5, 'a' + i);
for (std::size_t i = 0; i < size; ++i)
std::cout << "ptr[" << i << "] == " << ptr[i] << '\n';
std::destroy_n(ptr, size);
}
catch (...) {}
std::free(ptr);
}
}
输出:
p[0] == aaaaa
p[1] == bbbbb
p[2] == ccccc
p[3] == ddddd
参阅
| 分配函数 (函数) | |
(C++17 弃用)(C++20 移除) |
获得未初始化存储 (函数模板) |
malloc 的 C 文档
| |