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

Posted Z.L.G

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了指针做参数的动态内存分配与二重指针(上)相关的知识,希望对你有一定的参考价值。

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];

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

以上是关于指针做参数的动态内存分配与二重指针(上)的主要内容,如果未能解决你的问题,请参考以下文章

未解决问题:指针作参数二重指针指针数组动态内存分配

C - 读取文件并将文本放入具有动态内存分配的字符指针

指针和动态内存分配和释放

动态内存与智能指针

动态内存分配与指向它的指针变量

尝试使用动态内存分配创建节点指针数组