• const的自己理解


    说明:为什么标题是关于C++ const的记录,而不是C/C++关于const的记录.这是因为C语言的const和C++的const是有点区别的.

    至于什么区别,用一句话来说就是: C++中的const默认认为是内部连接,也就是说const仅在const被定义过的文件里才是可见的,而在连接时不能被其他编译单元看到.C语言的const默认认为时外部连接.

    这里主要讨论C++的const,C语言的const等需要的时候在仔细研究研究.

    一  头文件里的const

    默认的定义const,编译器是不会给const创建存储空间的,但有两个例外:

    • 使用extern声明为外部连接
    • 取const地址

    这两种情况编译器会给const分配内存空间.

    二  const的使用

    普通变量:

    1. void testConst()
    2. {
    3. const int i = 100;
    4. const int j = i + 10;
    5. const int *addr = &j;
    6. char buf[j + 10];
    7. std::cout << "i = " << i << std::endl;
    8. std::cout << "j = " << j << std::endl;
    9. std::cout << "j addr = " << addr << std::endl;
    10. std::cout << "*j addr = " << *addr << std::endl;
    11. std::cout << "buff sizeof = " << sizeof(buf) << std::endl;
    12. }

    输出:

     变量addr存储的是j的地址,所以*addr其实就是j,这两个是等价的,至于buf 的大小是120,是因为j=110,再加10就是120了.

    指针

     指向const的指针

     注意:这里有个注意点,就是指向const的指针和下面的const指针是两回事.

    const的读法:定义指针的技巧是在标识符的开始处读它,并从里向外读.

    demo:

    const int *u;

    首先明确一下u是一个指针,所以*u是不可以分离的.然后就是按照上面的技巧,在标识符(const)开始读它."u是一个指针,它指向const int".这里不需要初始化,因为u可以指向任何标识符(也就是说,它不是一个const),但是它指向的值是不能被改变的(指向的值是const).

    int const *v; 这个怎么读?

    首先明确v是一个指针,所以*v是一个整体.然后按照读法,在标识符开始处读它,并从里向外.

    "v是一个指针,它指向const的int的普通指针".

    即,const又把int结合在一起,效果与前面定义的一样.两个定义是一样的,这一点容易让人混淆.为了使程序具有可读性,应该坚持使用第一种.

    const指针

    使指针本身成为一个const指针,必须把const标明的部分放在*右边:

    demo:

    int d =1;

    int * const w;

    这个的读法:"w是一个指针,它指向int的const指针";因为指针本身现在是const指针,编译器要求给它一个初始值,这个值在指针生命周期内不变.然而要改变它锁指向的值是可以改变的:

    *w = 2;

    如果想地址和值都不能改变应该这怎么做.

    int d = 1;

    const int * const x = &d; 或者

    int const * const x2 = &d;

    赋值和类型检查

    1. 可以把一个非const对象的地址赋值给一个const指针.
    2. 不能把一个const对象的地址赋值给一个非const指针.(当然,总能用类型转换强制进行这样的赋值,但是这是一个不好的习惯,因为这样就打破了对象的const属性以及const提供的安全性)
    1. int d = 1;
    2. const int * const w = &d;
    3. int* x = (int*)w;
    4. std::cout << "d = " << d << std::endl;
    5. std::cout << "w = " << *w << std::endl;
    6. std::cout << "x = " << *x << std::endl;

    如果:

    int* x = w; 这样是错误的,因为违反了第二条.但是使用强制类型转换就可以了.

  • 相关阅读:
    第三章:最新版零基础学习 PYTHON 教程(第五节 - Python 运算符—Python 逻辑运算符及示例)
    SQL死锁进程内容查询语句
    非零基础自学Java (老师:韩顺平) 第7章 面向对象编程(基础部分) 7.8 构造方法构造器
    SpringBoot加载配置文件的顺序
    几个好用的数据标注软件labelme、CVAT及LabelImage
    Python 面向对象初步
    【halcon】halcon轮廓总结之select_contours_xld
    【Redis】List类型和底层原理
    qt 开发api文档地址
    Vue基础4
  • 原文地址:https://blog.csdn.net/m0_38036750/article/details/125682807