【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 int999; delete \[\]p;

    p1=55;

    *(p+1)=99;

  • 注意:

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

    第二个: 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;
}
相关推荐
郝学胜-神的一滴12 分钟前
完全二叉树与堆底层原理深度剖析 | 手写C++大顶堆实现
java·开发语言·数据结构·c++·python·算法
青山木14 分钟前
Hot 100 --- 缺失的第一个正数
算法·leetcode·哈希算法
农民小飞侠15 分钟前
[leetcode] 165. Compare Version Numbers
java·算法·leetcode
装不满的克莱因瓶26 分钟前
掌握语义分割经典模型 FCN——从像素分类到端到端分割的奠基之作
人工智能·python·深度学习·算法·机器学习·分类·数据挖掘
黄毛火烧雪下29 分钟前
Java 基础笔记:文件、递归与字符编码
java·开发语言·笔记
学计算机的计算基30 分钟前
链表算法上篇:LeetCode 206/234/141/142/160/21 题解与易错点
java·笔记·算法·链表
大白话_NOI35 分钟前
【洛谷 P2678】 [NOIP2015 提高组] 跳石头 超详细题解
c++·算法
xwz小王子37 分钟前
ICRA 2026深度观察:全栈闭环成标配,中国具身智能势力显著崛起
大数据·人工智能·算法
孬甭_39 分钟前
深入解析归并排序:稳定高效的分治典范
算法·排序算法
DXM05211 小时前
第14期|高阶分割模型:Transformer/SegFormer遥感应用
人工智能·python·神经网络·算法·计算机视觉·cnn·ageo