const修饰指针

  • const int *p:*p是常量
  • int * const p:p是常量

注意:const和int的位置可以互换

cpp 复制代码
#include <iostream>

void test1(){
    int i1 = 30;
    int i2 = 40;

    /**1、首先const修饰的是整个*pi,所以*pi是常量
     * 2、其次,pi前并没有const修饰,所以pi是指针变量,能被重新指向另一个内存地址
     * */
    const int *pi = &i1;

    //1、不可
    //*pi = i2;

    //2、可
    pi = &i2;

    //可
    i2 = 80;

    printf("%d/n", *pi);
}

void test2(){
    int i1 = 30;
    int i2 = 40;

    /**
     * 1、pi有const修饰,所以只是一个指针常量;也就是说pi的值不可以修改
     * 2、*pi的前面没有const的修饰,也就是说,*pi是变量而不是常量
     * 总结:这次的pi是一个指向int变量类型数据的指针常量
     * */
    int *const pi = &i1;

    //1、不可
    //pi = &i2;

    i1 = 80;

    //2、可
    *pi = 160;

    printf("%d/n", *pi);
    //int const * const p = &i1;
}

int main() {
    ///const int 和 int const是一样的,两个顺序可以颠倒
    ///但是const int *pi 和 int *const pi是不一样的
    test1();
    test2();

    return 0;
}
相关推荐
猿究院--王升2 小时前
jvm三色标记
java·jvm·算法
一车小面包2 小时前
逻辑回归 从0到1
算法·机器学习·逻辑回归
tt5555555555554 小时前
字符串与算法题详解:最长回文子串、IP 地址转换、字符串排序、蛇形矩阵与字符串加密
c++·算法·矩阵
元亓亓亓4 小时前
LeetCode热题100--101. 对称二叉树--简单
算法·leetcode·职场和发展
不会学习?5 小时前
算法03 归并分治
算法
NuyoahC5 小时前
笔试——Day43
c++·算法·笔试
2301_821919926 小时前
决策树8.19
算法·决策树·机器学习
秋难降6 小时前
别再用暴力排序了!大小顶堆让「取极值」效率飙升至 O (log n)
python·算法·排序算法
学行库小秘7 小时前
基于门控循环单元的数据回归预测 GRU
人工智能·深度学习·神经网络·算法·回归·gru
_meow_7 小时前
数学建模 15 逻辑回归与随机森林
算法·数学建模·逻辑回归