C++指针之(易错模型)


规则一:Main(主调函数)分配的内存(在堆区,栈区、全局区)都可以在被调用函数里使用。如果在被调用函数里面的临时区(栈)分配内存,主调用函数是不能使用的。

#include "stdio.h"
#include "stdlib.h"
#include "string.h"

char * getstring1()
{
    char *p1 = "abcde";
    return p1;
}

char * getstring2()
{
    char *p2 = "abcde";
    return p2;
}

char * getstring3()
{
    char buf[30];
    strcpy(buf, "abcde");
    return buf;
}

void main()
{
    int i= 0;

    //指针指向谁就把谁的地址赋给指针变量。
    char *p1 = getstring1();
    char *p2 = getstring2();
    char *******    p3 = NULL; //p3 是个变量
    char *p4 = getstring3();

//    printf("p1:%s\n", p1);
//    printf("p2:%s\n", p2);
//
//    printf("p1:%d\n", p1);
//    printf("p2:%d\n", p2);

    printf("p4:%s\n", p4);


    //指针变量和它所执行的内存空间变量是两个不同的概念
    strcmp(p1, p2);

    system("pause");
}

 

规则二:间接赋值,注意内存冲突。

 

#include "stdio.h"
#include "string.h"
#include "stdlib.h"
//看见一级指针,要去分辨指针的输入输出特性
//指针的输入特性:在主调函数里面分配内存,在被调用函数里面使用
//指针的输出特性:在被调用函数里面分配内存,主要是把运算结果甩出来
int getLen3(int *p /*in out*/)
{
    //*(NULL) = 40;
    //*(0)  = 40;
    *p = 40; //间接赋值 如果p是a的地址,那么就间接的修改a的值          //*p形参,去间接的修改实参的值
}
void main()
{
    int    a = 10; //定义了一个变量(实参)//a看成0级指针
    int *    p = NULL; ////定义了一个变量(形参)//1级指针
    a = 20; //直接修改a的值
    printf("a:%d \n", a);
    //p = &a; //a的地址赋给p //把一个变量去地址传给另外一个变量 //实参取地址传给形参
    getLen3(p);
    getLen3(NULL);   
    printf("a:%d \n", a);
    system("pause");
}   


//*(NULL) = 40;
//*(0)  = 40;
getLen3(NULL);

不同的编译器会有不同的提示。地址为为零的内存空间归系统所以,程序修改里面的内容,会出错。

本文永久更新链接地址

相关内容