以指针作为实参的问题

以指针作为实参时,实参p传递给形参p1的其实是p的拷贝,所以在局部函数中改变形参p1的指向对身处主函数的p是无影响的,但是因为p1是p的拷贝,

所以他们的指向是相同的,所以可以通过p1修改了那块内存的值。如果实参p的指向为空,也就是说p是一个空指针的话,那么它就没有指向某块内存,

形参也就无法操作p所指向的内存了(因为p本就没有指向任何一块内存),即使p1在局部函数中指向了一个malloc的空间,

这其实是改变了p1的指向(从NULL到指向malloc的空间),但是如前所述,p1只是p的拷贝,改变副本的指向对本尊是没有任何影响的,

所以对p没有影响,p还是为空。但是因为p1的生存周期是在局部函数范围内,所以一旦函数执行结束,p1这个变量就会被销毁释放,

但是那块malloc的空间却不会被释放,那就会成为空间碎片。

实参指针为空的一个例子:

#include <stdio.h>
#include <stdlib.h>

void f(int *p1)
{
    p1 = (int*)malloc(sizeof(int));
    *p1 = 100;
}

int main()
{
    int *p = NULL;
    f(p);
    printf("%d", *p);//程序崩溃,因为p是空指针,试图解引用一个空指针
    return 0;
}

实参指针不为空的一个例子:

#include <stdio.h>
#include <stdlib.h>

void f(int *p1)
{
    p1 = (int*)malloc(sizeof(int));    //改变了p1的指向,p1指向新分配的那块内存,对主函数中的p无任何影响
    *p1 = 100;
}

int main()
{
    int a = 10;
    int *p = &a;
    f(p);
    printf("%d", *p);    //输出为10
    return 0;
}

 传一个空指针时可以用二级指针

#include <stdio.h>
#include <stdlib.h>
 
void f(int **p1)
{
    *p1 = (int*)malloc(sizeof(int));
    **p1 = 100;
}
int main()
{
    int *p = NULL;
    f(&p);
    printf("%d", *p);//程序崩溃,因为p是空指针,试图解引用一个空指针
    return 0;
}

 

posted @ 2018-08-25 20:40  Lucky小黄人^_^  阅读(158)  评论(0编辑  收藏  举报