std::malloc
来自cppreference.com
在标头 <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 中移除) |
获得未初始化存储 (函数模板) |