指针做参数的动态内存分配与二重指针(上)
Posted Z.L.G
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了指针做参数的动态内存分配与二重指针(上)相关的知识,希望对你有一定的参考价值。
C中的动态内存分配问题:
格式:Int *pointer;
Pointer = (int *)malloc(100 * sizeof(int));
可以在被调用函数(该函数返回指针的函数)中动态分配内存,(并且该内存是分配在堆内存中的,故而被调函数可以返回指向该堆内存的指针),然后返回该指针值,该指针指向动态分配的内存,然后可以在主函数中free掉pointer。哪怕在主函数中将该指针值赋值给pointer_2,free掉pointer_2也是可以的,(可以理解的,它们都指向该堆内存),以避免出现内存泄漏。
对二维数组的动态内存分配与释放,我们知道在C++中直接int *pointer = new int[3][4]; 然后delete []pointer即可,C++可以直接对二维数组进行动态内存分配与释放。但是在C中,要么动态内存分配pointer= (int *)malloc(12 * sizeof(int)),也即直接分配一块连续的内存存放12个数组元素,而后free一次pointer;要么分配3块连续的动态内存分别存放4的数组元素,而后free三次pointer。后者需要用到指针数组来存放3个动态内存指针:int *pointer[3];注意与指向一位数组的指针区别:int (*pointer)[3].
第二种方法是挺复杂的。涉及到指针数组的动态内存分配问题。二重指针通常与指针数组一同使用,也即定义一个二重指针指向指针数组,可以理解的。两种方法范例源代码见下篇。
二重指针与指针数组的使用也是一定要注意的,还不熟练。
int **pointer; int *pointer_array[4]; pointer = pointer_array; //指针数组的数组名仍然代表地址
ATTENTION:
/**
pointer = pointer_array + 1 //这是合法的,pointer + 1 代表了数组pointer_array中第二个指针元素的地址
pointer= pointer_array[1] //这是非法的,pointer_array[1]代表了数组pointer_array中的第2个元素,也即数组中盛放的第二个指针,
我们是想把第二个指针的地址赋给pointer,而不是把第二个指针赋给pointer,会报错:error: cannot convert ‘int*‘ to ‘int**‘ in assignment
pointer_array[1]仅仅是指针,而pointer是指针的指针。
**/
上一段源码:
#include <stdio.h> int main() { int **pointer; int *p[3]; int a = 1; int b = 2; int c = 3; p[0] = &a; p[1] = &b; p[2] = &c; pointer = p; //pointer = p[0]; ///好好研究此处啊,它和上一行是不同的!!!看看error!! printf ("%d\n", *(*(pointer + 2))); return 0; }
如果要设计一个被调函数,该函数返回一个指向指针类型的指针,比如返回一个指针数组的地址,也就是返回一个二重指针,它的定义形式如下:
Int **allocation(parameter_1, parameter_2, ...)
以上是关于指针做参数的动态内存分配与二重指针(上)的主要内容,如果未能解决你的问题,请参考以下文章