• 详解:指针和指针类型


    指针和指针类型!

    指针就是地址,我想这句话,目前来说没有多大的毛病!

    指针变量就是用来存放地址的,地址是唯一的内存单元

    指针的大小在32位平台上是4字节,在64位平台上是8字节!

    因此:

        各指针所占字节,sizeof()所得结果是一样的,对于将信将疑的读者,下面请看笔者代码:

    1. #include
    2. int main()
    3. {
    4. int a = 10;
    5. int* pa = &a;
    6. char ch = "abc";
    7. char* pc = &ch;
    8. float fl = 9.0;
    9. float* pf = &fl;
    10. double dl = 5.0;
    11. double* pb = &dl;
    12. short so = 1;
    13. short* ps = &so;
    14. printf("%d\n", sizeof(pa));
    15. printf("%d\n", sizeof(pc));
    16. printf("%d\n", sizeof(pf));
    17. printf("%d\n", sizeof(pb));
    18. printf("%d\n", sizeof(ps));
    19. }

    笔者运转出来的代码为:  注意这里是64位平台所以显示的结果为8(需要注意不是所有的平台都是8,在32位平台结果是4)

     但是我们需要注意:

    对于;       char*的指针解引用访问1个字节

                   int*的指针解引用访问4个字节

                   double*的指针解引用访问8个字节

    下面来看用代码的分析情况:

    1. #include
    2. int main()
    3. {
    4. int a = 0x11223344; //十六位进制数字
    5. int* pa = &a;
    6. char* pc = &a;
    7. printf("pa=%p\n", pa); //用%p来打印地址
    8. printf("pa=%p\n", pc);
    9. printf("\n");
    10. //移动1个位地址,看看移动几个字节
    11. printf("pa=%p\n", pa+1);
    12. printf("pa=%p\n", pc+1);
    13. return 0;
    14. }

    在这里pa与pa+1;  pc与pc+1; 分别指地址往后移动一位!

     大家看代码的运行结果就可以知道:

    char*的指针解引用访问1个字节            int*的指针解引用访问4个字节

    指针类型决定了指针的步长(向前或者向后走一步,走多大的距离)

    因此,可以得出以下结论:

    int*指针+1:     意思是跳过1个整型,也就是向后走4个字节;

    char*指针 +1: 意思是跳过1个字符,也就是向后走1个字节;

    double指针+1:意思是跳过1个double,也就是向后走8个字节;

    short指针+1:  意思是跳过1个short,也就是向后走2个字节;

    本文章具体想表达的内容到此已经结束,读者要是有想要表达的思维逻辑,请联系笔者!

  • 相关阅读:
    第08章 中文分词
    Linux Find 备忘清单
    安卓讲课笔记5.4 单选按钮和复选框
    人工智能:PyTorch深度学习框架介绍
    吴恩达深度学习deeplearning.ai——第一门课:神经网络与深度学习——第二节:神经网络基础(上)
    基于Python实现的电梯进程及调度管理
    vulnhub靶机Vegeta
    LeetCode题目笔记——面试题 01.08. 零矩阵
    工作和生活中,如何用项目管理思维解决复杂的事情?
    使用 sqlc 生成类型安全的Go代码与SQL数据库交互
  • 原文地址:https://blog.csdn.net/weixin_64308540/article/details/126188842