我是靠谱客的博主 眼睛大小鸭子,最近开发中收集的这篇文章主要介绍char* 赋值 const char* 释放_C++引用,顶层const和底层const详解,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

C++的引用可以看成指针的语法糖。

引用本身不是一个对象。

为什么呢?假设你正在写一篇学术论文,要引用其它科学家的论文。于是就有:

论文& 引用论文1 = 其它科学家的论文;

这时,引用论文1其实就是“其它科学家的论文”的别名,可以看成引用除了空有一个名字啥也不是。如果“其它科学家的论文”并不存在,还引用什么呢!

const对象必须被初始化。(没什么好解释的)const其实只是一个对变量写权限的设定,并不代表某个变量永远不可能被修改。

如下例,只是不能从p处修改值而已,但是我们依然可以从temp处修改从而影响p的值。将p换成指针同理。

#include<iostream>
using namespace std;
int main(void)
{
int temp = 2;
const int& p = temp;//只是不能通过p改变temp,但是改变temp的值会改变p的值!
temp = 3;
//p只是temp的别名
cout << p << endl;
cout << temp <<endl;
}

int,double,float和long long等基本内置数据类型的const都是顶层const。

引用的const都是底层const。

指针既可以是顶层const也可以是底层const,也可以同时是两种const。

int *p;
//无const
const int *p;
//底层const,不能改变p所指向的值,能改变p的值
int* const p;
//顶层const,不能改变p的值,能改变p指向的值(典型的有clas中的this指针)
const int* const p;
//两种const,既不能改变p指向的值也不能改变p的值

底层const是不可忽略的。

const char* str = "996ICU251";
char *c = str;//不合法!

当执行对象的拷贝过程中(赋值操作,函数的值传递)时,如果被拷贝对象拥有底层const资格,则拷贝对象必须拥有相同的底层const资格

如果拷贝对象拥有底层const,则无所谓被拷贝对象是否有const。

总结:对于一个既是顶层const又是底层const对象来说,无所谓它是否为顶层const,只要关注它的底层const就行了。

const int p = 5;
//无外部链接
extern const int temp = 5;
//有外部链接的const 定义,在其他文件使用需声明
int temp = 2;
const int pi = 3.14;
const int& a = temp;
//合法,但temp改变会引起a改变
const int& b = 2;
//合法,编译器自动创建一个临时变量,然后将临时变量赋值给b
int& c = pi;
//不合法,c的值可以改变,但pi是const,与程序员本意矛盾
int& d = 2;
//不合法,因为不是const int&,编译器并不会创造一个临时变量来赋值

最后

以上就是眼睛大小鸭子为你收集整理的char* 赋值 const char* 释放_C++引用,顶层const和底层const详解的全部内容,希望文章能够帮你解决char* 赋值 const char* 释放_C++引用,顶层const和底层const详解所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(67)

评论列表共有 0 条评论

立即
投稿
返回
顶部