引用和const
1.C语言中的const(.c源文件哦)
不能直接修改,但是可以间接修改
2.C++中的const
1.常量不允许修改(直接/间接都不行)
2.常量必须初始化
即使通过手段(比如强转)使得常量的值发生了变化,但是出的值仍旧是最初的值
第二行是错的!!!
反证法,假设第二行表达式是对的,则没办法杜绝风险
所以第二行表达式:杜绝间接访问常量内存的风险,第二行是错的
2.1.const和指针的结合
1.修改办法:在21,22行前加const —> const *p=&a; (杜绝了间接访问的风险)
2.修改方法:在32行前加const(因为*p就是a,31也就代表着,变量a是不能被修改的,所以q前面必须加const,不然可能会改变a变量的值)
3. 正确的不用修改(因为现在const修饰的是一级指针p,与a变量无关,如果要修改p的值,必须是一个二级指针,q是个一级指针,没能力)
4.正确的,程序只从const那一行开始,往下看,有没有风险,因此p不需要修改
5.正确,只有二级指针才能修改一级指针
3.引用
引用的处理流程:引用在底层是一个指针。使用到引用变量的地方系统自带解引用的过程。
1.引用一定要初始化(有内存单元才能起别名)
2.引用 不能引用 不能取地址的数据(比如eax 寄存器没有地址,立即数)
3.引用不能改变
4.引用变量 只能操纵 引用变量所引用的 内存单元
3.1const和引用的结合(优化)
常引用:能引用 不能取地址的数据,把不能取地址的数据 放到一个临时量中,常引用来引用临时量
下图是合理的
3.2几道例题,理解一下(引用和局部变量,和返回值的结合)
1.19行对,20,21错,20行加const就对了,21行指针没有优化,不能改
tmp的值是从eax寄存器中带出来的,20,21行,寄存器没有地址,多以21,21错误
2.第一二三行对,第四行错
第四行右边是一个不能取地址的数据,引用一个不能取地址的数据是错误的
修改方法:int * const &pb=eax;
引用不参与类型
3. 全是对的
引用函数的返回值:整个函数的调用等同于引用变量
在底层,是寄存器带回返回值的地址,使用时自带解引用
不能返回局部变量的地址
不能返回局部变量的地址或引用
引用时别名,当局部变量被销毁,引用就没有意义了,越界操作: