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;
}
相关推荐
passer__jw7671 小时前
【LeetCode】【算法】3. 无重复字符的最长子串
算法·leetcode
passer__jw7671 小时前
【LeetCode】【算法】21. 合并两个有序链表
算法·leetcode·链表
sweetheart7-71 小时前
LeetCode22. 括号生成(2024冬季每日一题 2)
算法·深度优先·力扣·dfs·左右括号匹配
景鹤4 小时前
【算法】递归+回溯+剪枝:78.子集
算法·机器学习·剪枝
_OLi_4 小时前
力扣 LeetCode 704. 二分查找(Day1:数组)
算法·leetcode·职场和发展
丶Darling.5 小时前
Day40 | 动态规划 :完全背包应用 组合总和IV(类比爬楼梯)
c++·算法·动态规划·记忆化搜索·回溯
风影小子5 小时前
IO作业5
算法
奶味少女酱~5 小时前
常用的c++特性-->day02
开发语言·c++·算法
passer__jw7675 小时前
【LeetCode】【算法】11. 盛最多水的容器
算法·leetcode
诸葛悠闲5 小时前
C++ 面试问题集合
算法