C++标准模板(STL)- C 内存管理库 - 分配并清零内存 (std::calloc)

C 内存管理库

分配并清零内存

std::calloc

|-----------------------------------------------------|---|---|
| void* calloc( std::size_t num, std::size_t size ); | | |

分配 num 个大小为 size 的对象的数组,并初始化所有位为零。

若分配成功,则返回指向为任何对象类型适当对齐的,被分配内存块最低(首)字节的指针。

size 为零,则行为是实现定义的(可以返回空指针,亦可返回某个不可用于访问存储的非空指针)

|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| 要求下列函数是线程安全的: * operator new 及 operator delete 的库版本 * 全局 operator new 与 operator delete 的用户替换版本 * std::calloc 、 std::malloc 、 std::realloc 、 std::aligned_alloc (C++17 起) 、 std::free 对这些分配或解分配特定存储单元的函数调用以单独全序出现,并且在此顺序中,每个解分配调用先发生于下个分配(若存在)。 | (C++11 起) |

参数

|------|---|---------|
| num | - | 对象数量 |
| size | - | 每个对象的大小 |

返回值

成功时,返回指向新分配内存起始的指针。返回的指针必须以 std::free() 或 std::realloc() 解分配。

失败时,返回空指针。

注意

因为对齐要求,分配的字节数不需要等于 num*size

将所有位初始化为零不保证浮点数或指针各被初始化到 0.0 与空指针值(尽管大多数平台上这为 true )

最初( C89 中),添加对零大小的支持是为了接纳下面这种代码

调用示例

#include <iostream>
#include <cstdlib>
#include <string>

class MyString : public std::string
{
public:
    MyString() : std::string("GGX")
    {
        std::cout << __FUNCTION__ << std::endl;
    }

    MyString(size_type count, char ch)
        : std::string(count, ch)
    {
        std::cout << __FUNCTION__ << "  "
                  << static_cast<void *>(this) << std::endl;
    }

    ~MyString()
    {
        this->~basic_string();
        std::cout << __FUNCTION__ << "  "
                  << static_cast<void *>(this) << std::endl;
    }
};

int main()
{
    auto point = (int*)std::malloc(1 * sizeof(int));
    //打印未知字符
    std::cout << "std::malloc: " << point[0] << std::endl;

    MyString* point1 = (MyString*)std::calloc(4, sizeof(MyString)); // 分配并清零 4 个 int 的数组
    MyString* point2 = (MyString*)std::calloc(1, sizeof(MyString[4])); // 同上,直接指名数组类型
    MyString* point3 = (MyString*)std::calloc(4, sizeof * point3);  // 同上,不重复类型名

    if (point2)
    {
        for (int n = 0; n < 4; ++n) // 打印数组
        {
            std::cout << "point2[" << n << "] == " << point2[n] << std::endl;
        }
    }

    std::free(point1);
    std::free(point2);
    std::free(point3);

    return 0;
}

输出

std::malloc: 16387904
point2[0] ==
point2[1] ==
point2[2] ==
point2[3] ==
相关推荐
程序员_三木1 分钟前
Three.js入门-Raycaster鼠标拾取详解与应用
开发语言·javascript·计算机外设·webgl·three.js
是小崔啊11 分钟前
开源轮子 - EasyExcel01(核心api)
java·开发语言·开源·excel·阿里巴巴
tianmu_sama17 分钟前
[Effective C++]条款38-39 复合和private继承
开发语言·c++
黄公子学安全20 分钟前
Java的基础概念(一)
java·开发语言·python
liwulin050621 分钟前
【JAVA】Tesseract-OCR截图屏幕指定区域识别0.4.2
java·开发语言·ocr
jackiendsc26 分钟前
Java的垃圾回收机制介绍、工作原理、算法及分析调优
java·开发语言·算法
Oneforlove_twoforjob30 分钟前
【Java基础面试题027】Java的StringBuilder是怎么实现的?
java·开发语言
羚羊角uou32 分钟前
【C++】优先级队列以及仿函数
开发语言·c++
姚先生9736 分钟前
LeetCode 54. 螺旋矩阵 (C++实现)
c++·leetcode·矩阵
FeboReigns38 分钟前
C++简明教程(文章要求学过一点C语言)(1)
c语言·开发语言·c++