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
,比为文件读取分配缓冲区更可取。
[edit] 示例
运行此代码
#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
[edit] 另请参阅
分配函数 (函数) | |
(已在 C++17 中弃用)(已在 C++20 中删除) |
获取未初始化的存储空间 (函数模板) |
C 文档 for malloc
|