标签:
规则一: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);
不同的编译器会有不同的提示。地址为为零的内存空间归系统所以,程序修改里面的内容,会出错。
标签:
原文地址:http://www.cnblogs.com/CentForever/p/4640503.html