• 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; 这样是错误的,因为违反了第二条.但是使用强制类型转换就可以了.

  • 相关阅读:
    【linux kernel】以tftp方式启动linux内核
    荧光磷脂PEG衍生物之一磷脂-聚乙二醇-荧光素,Fluorescein-PEG-DSPE
    Python技法:用re模块实现简易tokenizer
    经典算法之直接插入排序法
    HIVE SQL计算一组值的中位数
    智能井盖生产商家,万宾科技井盖传感器产品详情
    Spiral Matrix
    【学到了】公司测试老鸟教我如何用postman+jmeter实现接口实例
    读书笔记(一)C++prime
    IDEA:开发配置(2024版 建议收藏)
  • 原文地址:https://blog.csdn.net/m0_38036750/article/details/125682807