zoukankan      html  css  js  c++  java
  • malloc/free和new/delete详解与应用

    C++面试经常会问到关于malloc/free和new/delete的区别,网上有不同版本的解释,这里总结下并加上个人理解和使用。

    两者相同点

    1.都可以申请动态堆内存。

    两者不同点

    1.new/delete是C++的操作符,malloc/free是C/C++的标准库函数。
    2.new申请的可以理解为对象,new时会调用构造函数,返回指向该对象的指针,delete时调用析构函数;malloc申请的只是内存,不是对象。

    3.new/delete是保留字,不需要头文件支持;malloc/free需要头文件库函数支持。

    注意事项

    1.用new申请的内存,必须用delete释放。
    2.用new[]申请的内存,必须用delete[]释放。
    3.delete释放内存后,指针值不变,良好的风格是释放后指针置为NULL,如,delete p; p = NULL。
    4.用malloc申请的内存,必须用free释放。

    使用

    #include "stdafx.h"
    #include <stdio.h>
    #include "stdlib.h"
    #include <string.h>
    
    struct Stu
    {
    	char	name[32];
    	int		age;
    };
    
    int main()
    {
    /**************************** 基本用法 **********************************/
    
    	//申请一个int类型
    	int *p1 = new int;		//直接申请赋值  int* p1 = new int(3);
    	int *p2 = (int*)malloc(sizeof(int));
    
    	//申请一个char类型
    	char *p3 = new char;	//直接申请赋值	char *p3 = new char('c');
    	char *p4 = (char*)malloc(sizeof(char));
    
    	//申请一个int型一维数组
    	int *p5 = new int[5];	//直接申请赋值	int *p5 = new int[5]{1,2,3,4,5};
    	int *p6 = (int*)malloc(sizeof(int)*5);
    	
    	//申请一个char型一维数组
    	char* p7 = new char[6]; //直接申请赋值  char* p7 = new char[3]{'a', 'v', 'c'};
    	char* p8 = (char*)malloc(sizeof(char)*6);
    	
    	//申请一个int型二维数组
    	int(*p9)[2] = new int[2][2]; //直接申请赋值	int(*p9)[2] = new int[2][2]{ 1,2,3,4 };
    	int(*p10)[2] = (int(*)[2])malloc(sizeof(int)*2*2);
    	
    	//申请一个char型二维数组
    	char(*p11)[2] = new char[2][2];
    	char(*p12)[2] = (char(*)[2])malloc(sizeof(char)*2*2);
    
    /***************************** 申请二级指针内存 **********************************/
    	
    	//申请二级指针(new,delete)
    	char** p13 = new char*[2];
    	p13[0] = "aaaaaaaaaa";
    	p13[1] = "vvvvvvvvvv";
    	delete p13;
    
    	//申请二级指针(malloc, free)
    	char** p14 = (char**)malloc(sizeof(char*)*2);
    	p14[0] = "cccccccc";
    	p14[1] = "dddddddd";
    	delete p14;
    
    /****************************** 申请结构体内存 *********************************/
    
    	//new delete
    	Stu* pStu1 = new Stu;
    	Stu* pStu2 = new Stu{"wpf",	10};
    	Stu* pStu3 = new Stu[1024];
    	delete pStu1;
    	delete pStu2;
    	delete[] pStu3;
    
    	//malloc free
    	Stu* pStu4 = (Stu*)malloc(sizeof(Stu));
    	memset(pStu4, 0, sizeof(Stu));
    	free(pStu4);
    
    	getchar();
    }

    欢迎加群交流:C/C++开发交流

  • 相关阅读:
    方法重载的小demo
    面向对象的小demo
    直接选择排序
    冒泡排序
    杨辉三角用java实现
    从键盘输入成绩,找出最高分,并输出学生成绩等级。成绩>=最高分-10,为A,成绩>=最高分-20,为B,成绩>=最高分-30,为C,其余等级为D
    井号的含义
    svg snap 笔记
    jQuery 插件格式 规范
    工作遇到问题
  • 原文地址:https://www.cnblogs.com/woniu201/p/11694599.html
Copyright © 2011-2022 走看看