C语言中的const

const修饰的变量是只读的,本质还是变量
const修饰的局部变量在栈上分配空间
const修饰的全局变量在只读存储区分配空间
const只在编译器有用,再运行期无用
const修饰的变量不是真的变量,只是告诉编译器该变量不能出现再赋值符号的左边
const使得变量只有只读属性
const将具有全局生命周期的变量存在只读存储区
const不是真正意义上的常量,只有枚举是真正意义的常量

C编译器:

#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;
    
}

输出结果:
Begin...
c = 5
End...

C++编译器:

#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;
    
}

输出结果:
Begin...
c = 0
End...

C++中的const

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

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

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

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

对const常量使用了extern
对const常量使用&操作符

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

image.png

C语言中的const变量

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

-可能分配存储空间

当const常量全局,并且需要在其他文件中使用
当使用&操作符对const常量取地址

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

const int c = 5; ≈#define c 5

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

const常量是由编译器处理
编译器对const常量进行类型检查和作用域检查
宏定义由预处理器处理,单纯的文本替换

#include "stdio.h"
void f()
{
    #define a 3
    const int b = 4;
}
void g()
{
    printf("a=%d\n",a);
}
int main()
{
    const int A = 1;
    const int B = 2;
    int array[A+B] = {0};
    int i = 0;
    for(i = 0;i<(A+B);i++)
    {
        printf("array[%d] = %d\n",i,array[i]);
    }    
    f();
    g();
    return 0;
}

image.png

小结

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


YingLi
6 声望4 粉丝

From zero to hero.