1,malloc与free是C++/C语言的标准库函数,new/delete是C++的运算符。它们都可用于申请动态内存和释放内存。 2,对于非内部数据类型的对象而言,光用maloc/free无法满足动态对象的要求。对象在创建的同时要自动执行构造函数,对象在消亡之前要自动执行析构函数。由于malloc/free是库函数而不是运算符,不在编译器控制权限之内,不能够把执行构造函数和析构函数的任务强加于malloc/free。 3,因此C++语言需要一个能完成动态内存分配和初始化工作的运算符new,以一个能完成清理与释放内存工作的运算符delete。注意new/delete不是库函数。 4,C++程序经常要调用C函数,而C程序只能用malloc/free管理动态内存。 5、new可以认为是malloc加构造函数的执行。new出来的指针是直接带类型信息的。而malloc返回的都是void指针。 一:new delete 是运算符,malloc,free是函数 malloc与free是C++/C语言的标准库函数,new/delete是C++的运算符。它们都可用于申请动态内存和释放内存。 对于非内部数据类型的对象而言,光用maloc/free无法满足动态对象的要求。对象在创建的同时要自动执行构造函数,对象在消亡之前要自动执行析构函数。由于malloc/free是库函数而不是运算符,不在编译器控制权限之内,不能够把执行构造函数和析构函数的任务强加于malloc/free。 因此C++语言需要一个能完成动态内存分配和初始化工作的运算符new,以及一个能完成清理与释放内存工作的运算符delete。注意new/delete不是库函数。
1.堆区------自由存储区 malloc new
2.动态开辟空间在堆区,静态开辟空间在栈区,手动开辟手动释放。
3.new 赋初始值
4 .静态数组是在定义是就已经在栈上分配了空间大小,在运行时这个大小不能改变,如:int a[10];
动态数组的大小是在运行是给定,即,运行时在堆上分配一定的存储空间,同时运行时还可以改变其大小,如: int *a; a = new int[10];
java 垃圾回收机制
c/c++ malloc new free delete
数组动态空间开辟 [],不能初始化,必须有默认构造函数
int * q = (int *)malloc((int)*size) //1.强制类型转换 2. 需要判空 3.free 4.不能初始化
int *q = new int[10] //new 1.不强制2.不用判空(错误抛出异常)3.delete []arr;
内存泄漏 和 重复释放都是不可取的
二、new 的三种形式
1.new operator
new操作符:两个工作:1先开辟空间operator new ,汇编实现。2. 调动构造函数
delete操作符:两个工作:1.先析勾对象 2.释放空间
2.operator new: 操作符new,也叫new的重载,void *的返回,参数是size_t
第一步:调动操作符new
第二步:调动构造函数,构造对象
operator delete:操作符delete,delete的重载:
第一步:先调动析勾函数,对象是指向数组的指针,若不析勾就会造成内存泄漏
第二步:释放空间
注意: delete释放了ps所指的空间,单是ps指向是void* ,系统不知道调动析构函数
3.placement new :定位new
定位new
placement new的重载函数的写法, 函数返回值是一个void* 的指针 函数名字operator new, 第一个参数一定是size_t类型的,new操作符内部计算,第二个参数是一个指向int类型的指针(int 类型数组),第三个是一个定位位子,返回一个&d[pos],即返回定位值得地址。
三、总结
new operator 和 operator new 以及placement new 的区别
四个步骤,相当于
1.操作符new只负责开辟空间
2.placement new定位new构造对象
3.指针调动析勾函数,析勾对象。相当于自杀(但指针不能调动构造函数,构造对象)
4.操作符delete 只负责释放申请的空间
静态开辟空间,动态开辟空间
定位new,就是调动操作符new
调动相应的重载函数