<!-- [if gte mso 9]><![endif]--><!-- [if gte mso 9]><![endif]--> <!-- [if gte mso 10]>new、new[ ]和delete、delete[ ]运算符和malloc,free函数:
<!-- [if gte mso 9]><![endif]--><!-- [if gte mso 9]><![endif]--><!-- [if gte mso 10]>
使用malloc函数和new[ ]运算符申请恰好存放100个double型数据的动态内存的写法分别如下:
double *p,*q;
p=(double*)malloc(sizeof(double)*100);
q=new double[100];
可以看出malloc函数申请内存以字节为单位,存放100个double型数据需要sizeof(double)*100个字节的内存;new[ ]运算符申请内存以数据类型为单位,申请存放100个double型内存的表达式为new double[100]。另外,malloc函数以void* 型返回申请内存的首地址,将这个地址存入具体的指针变量(不是void * 型)时需要强制转换数据类型;在new运算符构成的new表达式中,体现了所申请的内存未来存放数据的类型,所以不需要进行类型转换。
<!-- [if gte mso 9]><![endif]--><!-- [if gte mso 9]><![endif]--><!-- [if gte mso 10]>
值得注意的是,调用malloc函数申请内存时,要把表示申请内存长度的参数写在“( )”中,这是函数调用的一般形式;然而,使用new[ ]运算符申请内存时,要以数组形式写出申请内存的长度,数组长度写在“[ ]”中,而不是“( )”中。new表达式中的“( )”表示申请内存后,要对内存进行初始化。
new运算符申请供单个变量使用的内存时,可以使用“( )”为申请来的内存指定初始值,例如:
double q=new double(100);
<!-- [if gte mso 9]><![endif]--><!-- [if gte mso 9]><![endif]--><!-- [if gte mso 10]>
实际上,使用new、new[ ]运算符成功申请内存时,系统将做以下3件事情:
1. 分配申请的内存;
2. 根据初始值初始化已分配的内存(对于为自定义类型对象(变量)申请内存的情况,将会在已分配的内存上调用自定义类型某个版本的构造函数,关于自定义类型和构造函数,可参见第4章);
3. 返回已分配的内存的首地址。
使用malloc函数成功申请内存只做了上述3件事情的第1件和第3件,不会初始化分配来的内存(第2件事情)是malloc函数和new运算符申请内存时的最大区别。
在使用malloc函数和new、new[ ]运算符申请内存失败时,malloc函数返回值为0,new、new[ ]表达式通常抛出一个bad_alloc类型的异常.
<!-- [if gte mso 9]><![endif]--><!-- [if gte mso 9]><![endif]-->mso-paper-source:0;}div.Section1{page:Section1;}-->malloc函数申请的动态内存,delete[ ]运算符用于释放使用new[ ]运算符申请的动态内存,delete[ ]运算符的操作数是待释放内存的地址(指针).<!-- [if gte mso 10]>
引用和指针:
<!-- [if gte mso 9]><![endif]--><!-- [if gte mso 9]><![endif]--><!-- [if gte mso 10]>
引用和指针都被用来间接访问变量。但是,指针是独立于被指向变量的一个变量,指针有自己的内存空间。然而,引用仅仅是被引用变量的别名,引用没有自己的内存空间(起码在程序员的角度是这样的)。是否占用内存空间就是指针和引用的本质区别,因为有了这样的区别,在定义和使用它们时有如下几点不同。
1. 有空指针,而没有空引用。例如:
int &b=0;//错误,没有空引用
int *p=0;//正确,空指针代表指针暂时没有指向任何变量
3.<FONT face="""> 引用在初始化后,不会变更引用的对象,而指针可以变更所指向的对象。例如:
int a1,a2;
int &b=a1;//b是a1的引用
int *p=&a1;//p是a1的指针
p=&a2;//p成为a2的指针,不再指向a1
b=a2;//语法正确,是将a2的值存入b,等价于存入a1,但不是改变b为a2的引用。