指针做参数的动态内存分配与二重指针(上)

C中的动态内存分配问题:

格式:Int *pointer;

Pointer = (int *)malloc(100 * sizeof(int));

可以在被调用函数(该函数返回指针的函数)中动态分配内存,(并且该内存是分配在堆内存中的,故而被调函数可以返回指向该堆内存的指针),然后返回该指针值,该指针指向动态分配的内存,然后可以在主函数freepointer。哪怕在主函数中将该指针值赋值给pointer_2freepointer_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];        //指针数组要对数组元素赋值,也即对数组里面的指针元素赋地址值,而非对指针元素指向的整型数据赋数值,otherwise编译出错

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, ...)

posted on 2017-11-01 13:01  Z.L.G  阅读(1855)  评论(0编辑  收藏  举报

导航