第3课-进化后的const

1. C语言中的const

  • const修饰的变量是只读的,本质还是变量

  • const修饰的局部变量在栈上分配空间

  • const修饰的全局变量在只读存储区分配空间

  • const只在编译期有用,在运行期无用

  • C语言中的const使得变量具有只读属性

  • const将具有全局生命周期的变量存储于只读存储区

PS:

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

(2) const不能定义真正意义上的常量

#include <stdio.h>

int main()
{
    const int c = 3;
    int* p = (int*)&c;
    
    printf("Begin...\n");
    
    *p = 5;
    
    printf("c = %d\n", c);  // 在C语言中打印5,C++中打印3
    
    printf("End...\n");
    
    return 0;
}

 

2. C++中的const

  • C++在C的基础上对const做了进化处理

    - 当碰见const声明时在符号表中放入常量

    - 编译过程中若发现使用常量则直接以符号表中的值替换

    - 编译过程中若发现以下情况则给对应的常量分配存储空间

      (1) 对const常用使用extern

      (2) 对const常用使用&操作符

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

 

  • C语言中的const变量

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

  • C++中的const常量

    - 可能分配存储空间

      (1) 当const常量为全局,并且需要在其它文件中使用

      (2) 当使用&操作符对const常量取地址

  • C++中的const常量类似于宏定义

    - const int c = 5 ≈ #define c 5

  • C++中的const常量与宏定义的不同

    - const常量是由编译器处理

    - 编译器对const常量进行类型检查作用域检查

    - 宏定义由预处理器处理,单纯的文本替换

#include <stdio.h>

void f()
{
    #define a 3
    const int c = 4;
}

void g()
{
    printf("a = %d\n", a);
    printf("c = %d\n", c);    // 编译出错
}

int main()
{
    const int A = 1;
    const int B = 2;
    int array[A+B] = {0};    // 在C编译器中编译不过
    
    int i = 0;
    
    for(i = 0; i < (A + B); i++)
    {
        printf("array[%d] = %d\n", i, array[i]);
    }
    
    f();
    g();
    
    return 0;
}

 

3. 小结

  • 与C语言不同,C++中的const不是只读变量

  • C++中的const是一个真正意义上的常量

  • C++编译器可能会为const常量分配空间

  • C++完全兼容C语言中的const常量的语法特性

 

 

本文出处:狄泰软件学院

posted @ 2020-03-09 21:20  WisdomMan  阅读(3)  评论(0)    收藏  举报