【C++】C++中的动态内存分配(new和delete)

C++中的动态内存分配(分配堆空间)

1. C语言与C++动态内存分配

  • C语言

    malloc calloc realloc free 函数

  • C++

    new关键字分配堆空间

    delete关键字释放堆空间

2. 使用

  • 第一种:分配一个int大小的堆空间

    int *p=malloc(sizeof(int));
    int *p=new int; delete p;

  • 第二种:分配一个int大小的堆空间,并赋值

    int *p=malloc(sizeof(int));

    *p=999;
    int *p=new int(999); delete p;

  • 第三种:分配多个int大小的堆空间

    int p=malloc(999 sizeof(int));
    int *p=new int[999]; delete []p;

    p[1]=55;

    *(p+1)=99;

  • 注意:

    第一个: new int(999)和new int[999]的区别

    第二个: delete只要new分配堆空间的时候使用了[],那么delete对应写上[]

3.malloc和new有什么区别

  • 区别1:malloc是个库函数,new是关键字
  • 区别2:free释放,delete释放

示例代码:

cpp 复制代码
#include <iostream>  //C++的标准输入输出流头文件
#include <cstring>  //#include <string.h>
using namespace std; //我要使用命名空间std
/*
    new申请堆空间
       公式:new 数据类型
    delete释放堆空间
*/

struct student
{
    char name[10];
    int age;
};

int main()  
{
    //申请一个int大小的堆空间
    int *p=new int;  //int *p=malloc(sizeof(int))
    
    //申请多个int大小的堆空间
    int *p1=new int[10];  //int *p1=malloc(10*sizeof(int))
    
    //申请一个int大小的堆空间,给它赋初始值
    //()表示赋值,[]表示申请多少个类型的堆空间
    int *p2=new int(10);  //int *p2=malloc(sizeof(int))  *p2=10
    
    struct student *p3=new struct student;
    struct student *p4=new struct student[8];
    
    //使用堆空间--》C语言的知识
    *p=456;
    *p1=10;       //p1[0]=10
    *(p1+1)=11;   //p1[1]=11
    strcpy(p3->name,"张三");
    p3->age=18;
    
    cout<<"*p is: "<<*p<<endl;
    cout<<"*p2 is: "<<*p2<<endl;
    //释放堆空间
    //如果申请的时候用到了[],释放的时候就必须用[]
    delete p;
    delete []p1;
    delete p2;
    delete p3;
    delete []p4;
    return 0;
}
相关推荐
灰子学技术4 小时前
go response.Body.close()导致连接异常处理
开发语言·后端·golang
那个村的李富贵5 小时前
CANN加速下的AIGC“即时翻译”:AI语音克隆与实时变声实战
人工智能·算法·aigc·cann
二十雨辰5 小时前
[python]-AI大模型
开发语言·人工智能·python
power 雀儿5 小时前
Scaled Dot-Product Attention 分数计算 C++
算法
Yvonne爱编码5 小时前
JAVA数据结构 DAY6-栈和队列
java·开发语言·数据结构·python
Re.不晚5 小时前
JAVA进阶之路——无奖问答挑战1
java·开发语言
你这个代码我看不懂5 小时前
@ConditionalOnProperty不直接使用松绑定规则
java·开发语言
pas1365 小时前
41-parse的实现原理&有限状态机
开发语言·前端·javascript
琹箐5 小时前
最大堆和最小堆 实现思路
java·开发语言·算法
renhongxia16 小时前
如何基于知识图谱进行故障原因、事故原因推理,需要用到哪些算法
人工智能·深度学习·算法·机器学习·自然语言处理·transformer·知识图谱