std::malloc
来自cppreference.com
在标头 <cstdlib> 定义
|
||
void* malloc( std::size_t size ); |
||
分配 size
字节的未初始化存储。
若分配成功,则返回指向分配的适合对任何标量类型对齐的内存块中,最低(首)字节的指针。
若 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 <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 中移除) |
获得未初始化存储 (函数模板) |