std::malloc
来自 cppreference.cn
定义于头文件 <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 表达式。
对于加载大文件,通过 OS 特定函数进行文件映射,例如 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 中已移除) |
获取未初始化存储 (函数模板) |
C 文档 for malloc
|