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;
}
相关推荐
我叫汪枫3 分钟前
C语言深度入门系列:第十一篇 - 动态内存管理与数据结构:程序世界的高效算法大师
c语言·数据结构·算法
Li_7695327 分钟前
优选算法100 题 ——1 双指针
算法
77qqqiqi10 分钟前
算法——数学基础
算法
啊?啊?10 分钟前
7 排序算法通关指南:从 O (n²)(选择 / 冒泡)到 O (nlogn)(快排 / 归并)+ 计数排序
数据结构·算法·排序算法
张较瘦_13 分钟前
[论文阅读] 算法 | 抗量子+紧凑!SM3-OTS:基于国产哈希算法的一次签名新方案
论文阅读·算法·哈希算法
芒克芒克15 分钟前
LeetCode 面试经典 150 题:多数元素(摩尔投票法详解 + 多解法对比)
算法·leetcode·面试
wow_DG15 分钟前
【Vue2 ✨】Vue2 入门之旅 · 进阶篇(二):虚拟 DOM 与 Diff 算法
开发语言·javascript·vue.js·算法·前端框架
和光同尘 、Y_____17 分钟前
BRepMesh_IncrementalMesh 重构生效问题
c++·算法·图形渲染
sali-tec1 小时前
C# 基于halcon的视觉工作流-章32-线线测量
开发语言·人工智能·算法·计算机视觉·c#
lingran__1 小时前
速通ACM省铜第一天 赋源码(The Cunning Seller (hard version))
c++·算法