C++之const

C语言中的const

  • const 修饰的变量是只读的,本质还是变量
  • const 修饰的局部变量在栈上分配空间
  • const 修饰的全局变量在只读存储区分配空间
  • const 只在编译期有用,在运行期无用

const修饰的变量不是真的常量,它只是告诉编译器该变量不能出现在赋值符号的左边

  • C语言中的const使得变量具有只读属性
  • const将具有全局生命周期的变量存储于只读存储区

const 不能定义真正意义上常量

#include<stdio.h>
int main()
{
    const int c = 0;
    int *p = (int *)&c;
    printf("Begin...\n");

    *p = 5;
    printf("c = %d\n",c);
    printf("End...\n");

    return 0;
}
  • 编译结果
    • gcc test.c –> c = 5
    • g++ test.cpp –> c = 0

C++中的const

  • C++在C的基础上对const进行了进化处理
  • 当碰见 const 声明时在符号表中放入常量
  • 编译过程中若发现使用常量则直接以符号表中值替换
  • 编译过程中若发现下述情况则给对应的常量分配存储空间
    • 对const 常量使用了extern
    • 对const 常量使用& 操作符

注意: C++编译器虽然可能为const常量分配空间,但不会使用其存储空间的值

图1

  • 图1解释 test.cpp 中的c = 0的原因

区别

  • C语言中的const 变量

    • C语言中const 变量是只读变量,会分配存储空间
  • C++中的const 常量

    • 可能分配存储空间 
      • 当const 常量为全局,并且需要在其它文件中使用
      • 当使用&操作符对const常量取地址
  • C++中的const 常量类似于宏定义
    • const int c = 5; ≈ #define c 5
  • C++ 中的const 常量在与宏定义不同
    • const 常量是由编译器处理
    • 编译器对const常量进行类型检查和作用域检查
    • 宏定义由预处理器处理,单纯的文本替换

小结

  • 与C语言不同,C++中的const不是只读变量
  • C++中的const是一个真正意义上的常量
  • C++编译器可能会为const常量分配空间
  • C++完全兼容C语言中const常量的语法特性

猜你喜欢

转载自blog.csdn.net/z2066411585/article/details/79722084