1、关于const的疑问
const 什么时候为只读变量?
什么时候是常量?
const常量的判别准则
- 只有用字面量初始化的const常量才会进入符号表
-使用其它变量初始化的const常量仍然是只读变量
-被volatile修饰的const常量不会进入符号表
在编译期间不能直接确定初始值的const标识符,
都被作为只读变量处理。
const引用的类型与初始化变量的类型
-相同:初始化变量成为只读变量
-不同:生成—个新的只读变量
2、编程实验
const典型问题分析 12-1.cpp
- #include <stdio.h>
- int main()
- {
- const int x = 1;
- const int& rx = x;
- int& nrx = const_cast<int&>(rx);
- nrx = 5;
- printf("x = %d\n", x);
- printf("rx = %d\n", rx);
- printf("nrx = %d\n", nrx);
- printf("&x = %p\n", &x);
- printf("&rx = %p\n", &rx);
- printf("&nrx = %p\n", &nrx);
- volatile const int y = 2;
- int* p = const_cast<int*>(&y);
- *p = 6;
- printf("y = %d\n", y);
- printf("p = %p\n", p);
- const int z = y;
- p = const_cast<int*>(&z);
- *p = 7;
- printf("z = %d\n", z);
- printf("p = %p\n", p);
- char c = 'c';
- char& rc = c;
- const int& trc = c;
- rc = 'a';
- printf("c = %c\n", c);
- printf("rc = %c\n", rc);
- printf("trc = %c\n", trc);
- return 0;
- }
如何理解"引用的本质就是指针常量" ?
指针是—个变量
-值为—个内存地址,不需要初始化,可以保存不同的地址
-通过指针可以访问对应内存地址中的值
-指针可以被const修饰成为常量或者只读变量
引用只是—个变量的新名字
-对引用的操作(赎值,取地址等)都会传递到代表的变量上
- const引用使其代表的变量具有只读属性
-引用必须在定义时初始化,之后无法代表其它变量
从使用C++语言的角度来看
-引用与指针没有任何的关系
-引用是变量的新名字,操作引用就是操作对应的变量
从C++编译器的角度来看
-为了支持新概念“引用”必须要—个有效的解决方案
-在编译器内部,使用指针常量来实现“引用”
-因此“引用”在定义时必须初始化
在工程项目开发中
-当进行C++编程时,直接站在使用的角度看待引用,
与指针毫无关系,引用就是变量的别名
-当对C++代码进行调试分析时,—些特殊情况,可以
考虑站在 C++编译器的角度看待引用
下面的代码有问题吗?
- int a= 1;
- int b = 2;
- int* pc= new int(3);
- int& array[] = {a, b, *pc};
3、编程实验
引用典型问题分析 12-2.cpp
- #include <stdio.h>
- int a = 1;
- struct SV
- {
- int& x;
- int& y;
- int& z;
- };
- int main()
- {
- int b = 2;
- int* pc = new int(3);
- SV sv = {a, b, *pc};
- // int& array[] = {a, b, *pc}; // &array[1] - &array[0] = ? Expected ==> 4
- printf("&sv.x = %p\n", &sv.x);
- printf("&sv.y = %p\n", &sv.y);
- printf("&sv.z = %p\n", &sv.z);
- delete pc;
- return 0;
- }
test.cpp:17:16:error: declaration of ‘array’ as array of references
对比地址发现为了兼容C语言所有特性,放弃引用数组
所以C++不支持引用数组
4、小结
指针是—个变量
引用是一个变量的新名字
const引用能够生成新的只读变量
在编译器内部使用指针常量实现“引用”
编译时不能直接确定初始值的const标识符都是只读变量