c++中新的和malloc的区别及使用

介绍

本篇内容介绍了c++中新的和malloc的区别及使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

定义上:malloc内存分配动态内存分配是C中的一个函数

使用方法:

走读生void * malloc (unsigned int num_bytes)

走读生void * malloc (unsigned int num_bytes)

um_bytes内存块字节长度。

内存块大小确定:malloc是通过我们计算然后得到一块新内存,然后指定数据类型并且内存值也是随机的。

使用时:需要引入头文件库函数stdlib。h或是malloc.h (malloc.h与alloc.h一致)。

内存分配位置:堆中动态分配的内存。

具体分配过程:由程序向操作系统申请,操作系统遍历空闲结点链表,将第一个大于申请空间的堆结点分配给程序,然后将空闲结点链表中此节点删掉。

成功分配:返回值为指向被分配内存的指针。

失败分配:返回值为空为空。

返回类型:void *(未确定类型的指针)。

void *类型可以通过强制类型转换转换为任意其他类型(因为用户存储数据类型未知,由用户决定数据类型)。

内存块释放:自由()函数将内存还给程序或操作系统。

注意:malloc与自由都属于c/c++标准库函数,在使用时应该配对申请之后不释放就会有可能发生内存泄漏。

使用自由时需要检查指针是否为空。

电子战是c++中的运算符(其地位等同于“+”,“=?。

在使用:新时不止分配内存,还会进行初始化,执行相应构造函数,初始化时需要指定数据类型。

内存分配位置:自由存储区为对象分配内存。

使用时:无需引入头文件,新的是保留字吗?

ew和删除是配对使用的。

在使用删除时注意将指针置为0,否则会形成悬垂指针(指针所指内存已被释放,仍指向该内存),造成错误?

电子战可以看做是malloc加构造函数的执行,就是新的更高级一些吗?

电子战的几种用法:

1 int * p=new int;//在自由存储区开辟一个int变量2 int * p=new int[10];//在自由存储区开辟一个int数组,有10个元素3 int * p=new int(10);//在自由存储区开辟一个int变量,并初始化为10

释放内存时无需检查是否为空。

如果p等于空,则删除p不作任何事情。由于之后可以得到测试,并且大多数的测试方法论都强制显式测试每个分支点,因此你不应该加上多余的如果测试。

错误的:

1如果2删除p (p !=NULL);3正确的:删除

面试时可能会问到的问题:

1)它们都可用于申请动态内存和释放内存?

2) malloc是库函数只能作用于内部数据类型,对于非内部数据动态对象而言,就不能完成对象的初始化与销毁,即执行构造函数与析构函数,而新与删除此类运算符就能够在编译器的控制权限内完成,对象的初始化与销毁任务,即执行构造函数与析构函数?

既然新/删除的功能完全覆盖了malloc/free,为什么c++不把malloc/free淘汰出局呢?这是因为c++程序经常要调用C函数,而C程序只能用malloc/free管理动态内存?

我们不要企图用malloc/free来完成动态对象的内存管理,应该用新/删除?由于内部数据类型的“对”象没有构造与析构的过程,对它们而言malloc/free和新/删除是等价的?

注意:如果用自由释放“新创建的动态对象”,那么该对象因无法执行析构函数而可能导致程序出错?

如果用删除释放“malloc申请的动态内存”,结果也会导致程序出错,但是该程序的可读性很差吗?所以新/删除必须配对使用,malloc/free也一样?

零值指针,是值是0的指针,可以是任何一种指针类型,可以是通用变体类型void *也可以是char *, int *等等?空指针,其实空指针只是一种编程概念,就如一个容器可能有空和非空两种基本状态,而在非空时可能里面存储了一个数值是0,因此空指针是人为认为的指针不提供任何地址讯息吗?

内存泄漏对于malloc或新者都可以检查出来的,区别在于新的可以指明是那个文件的那一行,而malloc没有这些信息吗?

c++中新的和malloc的区别及使用