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