c语言,通过代码对指针的理解

int a = 5;
int *b;
b = a;//b的存储空间里放入的是a,不是内存地址,*b意味着b的存储空间的内容(指针)所指向的内存地址的存储空间的内容(卧槽,我都觉得别嘴),所以当b的存储空间内容不是内存地址(指针)时,printf打印*b时会报错bad_access,
printf("a:%d,&a:%d---b:%d,&b:%d,*b:%d\n",a,&a,b,&b,b);
打印结果:a:5,&a:1606416276---b:5,&b:1606416264,*b:5

b = &a;//b的存储空间放的是a的内存地址,所以printf可以打印*b
printf("a:%d,&a:%d---b:%d,&b:%d,*b:%d\n",a,&a,b,&b,*b);
打印结果:a:5,&a:1606416276---b:1606416276,&b:1606416264,*b:5

int *c = b;//直接声明时,*c意味着c的存储空间内容是b存储空间的内容,相当于复制了一遍b,只不过内存地址不一样而已
printf("a:%d,&a:%d---b:%d,&b:%d,*b:%d---c:%d,&c:%d,*c:%d\n",a,&a,b,&b,*b,c,&c,c);
打印结果:a:5,&a:1606416276---b:1606416276,&b:1606416264,*b:5---c:1606416276,&c:1606416256,*c:1606416276

*c = 1;//此时的*c意味着c所指向的内存地址的存储空间内容改变为1,也就是将a变量的值改为1,但是b、c的存储空间和内存地址都没改变,只不过*b、*c的值被改变
printf("a:%d,&a:%d---b:%d,&b:%d,*b:%d---c:%d,&c:%d,*c:%d\n",a,&a,b,&b,*b,c,&c,*c);
打印结果:a:1,&a:1606416276---b:1606416276,&b:1606416264,*b:1---c:1606416276,&c:1606416256,*c:1

a = 4;//a单纯的改变存储空间的内容,所以*b、*c的值都改变,b、c的存储空间内容和内存地址都没改变
printf("a:%d,&a:%d---b:%d,&b:%d,*b:%d---c:%d,&c:%d,*c:%d\n",a,&a,b,&b,*b,c,&c,*c);
打印结果:a:4,&a:1606416276---b:1606416276,&b:1606416264,*b:4---c:1606416276,&c:1606416256,*c:4

b = 3;//b只改变了自己存储空间的内容,原内容是指向a的指针,现改为数字3,所以a、c值都没有发生变化
printf("a:%d,&a:%d---b:%d,&b:%d,*b:%d---c:%d,&c:%d,*c:%d\n",a,&a,b,&b,b,c,&c,*c);
打印结果:a:4,&a:1606416276---b:3,&b:1606416264,*b:3---c:1606416276,&c:1606416256,*c:4

c = 2;//同b=3一致
printf("a:%d,&a:%d---b:%d,&b:%d,*b:%d---c:%d,&c:%d,*c:%d\n",a,&a,b,&b,b,c,&c,c);
打印结果:a:4,&a:1606416276---b:3,&b:1606416264,*b:3---c:2,&c:1606416256,*c:2

b = &a;
int *d = &b;//与c不同,将b的内存地址放入d的存储空间
printf("a:%d,&a:%d---b:%d,&b:%d,*b:%d---d:%d,&d:%d,*d:%d\n",a,&a,b,&b,*b,d,&d,*d);
打印结果:a:4,&a:1606416276---b:1606416276,&b:1606416264,*b:4---d:1606416264,&d:1606416248,*d:1606416276

*d = a;//*d意味着d的存储空间所指向的内存地址的存储空间内容(即b的存储空间内容)改为a的值,所以printf时不能打印*b
printf("a:%d,&a:%d---b:%d,&b:%d,*b:%d---d:%d,&d:%d,*d:%d\n",a,&a,b,&b,b,d,&d,*d);
打印结果:a:4,&a:1606416276---b:4,&b:1606416264,*b:4---d:1606416264,&d:1606416248,*d:4

存储空间和内存地址的关系如图:


图片出处:http://blog.csdn.net/tianmaxingkong_/article/details/41593483 在此表示感谢


    //指针++
    int a = 5;
    int *b;
    b = &a;
    printf("a:%d,&a:%d,*a:%d---b:%d,&b:%d,*b:%d\n",a,&a,a,b,&b,*b);
    //打印结果:a:5,&a:1606416252,*a:5---b:1606416252,&b:1606416240,*b:5
    
    b++;//此时的b++ 意味着b的存储空间内容++,内容为1606416252,int类型占4字节,所以b++后为1606416256,即指向下一个内存地址的内容,而1606416256内存地址的存储空间内容不清楚,所以*b的结果很随机
    printf("a:%d,&a:%d,*a:%d---b:%d,&b:%d,*b:%d\n",a,&a,a,b,&b,*b);
    
    //指针与一维数组(二维数组原理一致)
    int array[10],*p;
    p = array;//此时相当于将二维数组的第一个元素的地址赋予p,相当于 p = &array[0]
    for (int i = 0; i < 10; i++) {
        *p++ = i;
        //此时的*p++不会像 指向int类型时一次跳4个字节,此时会跳到下一个字节,即array下一个元素的内存地址
    }
    p = array;//将p指针重新指回到array数组的首元素地址
    for (int j = 0; j < 10; j++ ) {
        printf("array[%d] : %d\n", j, *p++);//依次将指针后移,打印所有数组元素
    }

    //指针与字符串,与数组原理相同
    char str1[] = "you are so beautiful";
    char str2[] = "";
    char *p1,*p2;
    p1 = str1;
    p2 = str2;
    
    while (*p1 != '\0') {
        *p2 = *p1;
        p1++;
        p2++;
    }
    printf("str2[] is :%s\n", str2);
    打印结果:str2[] is :you are so beautifull

int类型的指针++内存示意图:


数组类型的指针++内存示意图:




猜你喜欢

转载自blog.csdn.net/jbb0403/article/details/72918522
今日推荐