malloc/free和new/delete 共同点
malloc/free和new/delete的共同点是:都是从堆上申请空间,并且需要用户手动释放。都是动态内存分配的方式
malloc/free 和 new/delete的不同
1 malloc/free 是函数 new/delete 是关键字
2 malloc 申请的空间不可以初始化(malloc 只管分配内存,并不能对所得的内存进行初始化,所以得到的一片新内存中,其值将是随机的。)而new出来的空间可以初始化(使用()进行构造函数传参,而new数组时,可以使用【10】来开辟指定空间大小的数组)
3 malloc 申请空间时需要计算手动计算大小,并将其传递,而new后面只需要跟类型
4 malloc 的返回值类型是void* ,在使用时需要强转。new不需要,因为new后面跟的是类型,其返回的就是相应类型的指针
5 malloc 申请空间失败时 返回NULL 需要判断是否为空, new 不需要,但是new需要捕获异常
6 申请自定义对象时, new 和delete 会分别调用 构造函数和析构函数 ,完成对象的创建的资源的回收,而malloc/free 不会调用构造函数和析构函数 .
malloc的底层
malloc小于128k的内存,使用brk分配内存,将_edata往高地址推;malloc大于128k的内存,使用
mmap分配内存,在堆和栈之间找一块空闲内存分配;brk分配的内存需要等到高地址内存释放以后才能
释放,而mmap分配的内存可以单独释放。
如果用new创建对象,再用free去释放内存,结果会怎么样呢?
根据定义:new()函数实际过程中做了两步操作,第一步是分配内存空间,第二步是调用类的构造函数;delete()也同样是两步,第一步是调用类的析构函数,第二步才是释放内存;而malloc()和free()仅仅是分配内存与释放内存操作;
那么如果通过new分配的内存,再用free去释放,就会少一步调用析构函数的过程。同时,在构造函数里面申请的内存因为没有调用析构函数,所以该内存并没有释放,所以如果再输出该内存的值,那么应该还是原来设置的值100;