之前总感觉C/C++中有const 限定的变量是个很头痛的问题,一会儿能够变。一会儿不能够变,一会儿把const赋给nonconst,一会儿又把nonconst赋给const,头都被它搞大了。今天刚好把《C++ primer》中的相关部分又读了一遍,所以就把相关的内容写出来总结一下啦!

首先,我们能够想想为什么要设计const变量这样的东西,只是就是想有个常量嘛!所以对const类型变量进行操作的核心原则就是不能改变该变量的值。其它操作的话。const还是不const影响事实上不大。

然后我们能够想到的是,既然在程序运行过程中。不能改变const变量的值,那么我们在对该变量进行定义的时候就必须对它进行初始化。

对于像int,double这种普通变量来说。初始化一般有例如以下三种方式:

const int i = fun(); //利用函数返回值初始化
const int j = 42;//字面值
const int k = i;//其它变量

这里我们值得注意的是第一种和第三种的赋值方式。

我们可能会有这种疑问,万一i的类型或者fun函数的返回值的类型不是const int类型的怎么办呢?这时候我们就能够想想前面提到过的那个原则了。

因为赋值仅仅是将一个变量的值赋给另外一个。从此之后两者就基本上每什么关系了。

所以不会对原来const类型变量的值产生影响。

所以赋值操作全然能够无视等号两边的变量类型。

普通类型变量的const相关问题还是非常easy的,以下就再来讲讲reference(引用)和pointer(指针)的相关问题。我们都知道引用类型也是必需要初始化的,而且在初始化之后不能再将该引用指向其它的变量。

这点与指针有非常大的不同。所以我们全然能够觉得引用本身就是const的,由于它自己的值是不能改变的。

如今我们有以下四个赋值语句:

int       j
const int i; const int &r1 = i;
int &r2 = j;
const int &r3 = j;
int &r4 = i;

非常明显,前面两条的赋值语句是不会有不论什么问题的,由于等号两变的变量类型是全然一样的。其实我们全然能够将一个const类型的引用指向一个nonconst类型的变量。就像第三个等式一样。由于我们仅仅要保证变量的值不能通过r3进行改变就能够了。至于实际上j的值变不变是不在r3的管辖范围之内的,或者说即使变了也无所谓,j本来就是nonconst类型的。可是,假设反过来将一个noncosnt类型的引用指向一个const类型的变量就不行了,由于你此时能够同过r4去改变一个const类型变量的值。

最后我们来看看指针类型的const问题。例如以下所看到的,对于一个指针变量来说。const通常会存在在两个位置:

int        a;
const int *p = &a;
int *const q = &a;

对于第一种类型。我们能够和对引用的操作做一个类比,事实上是几乎相同的。那么对于第二中声明怎么解读呢?正如《C++ primer》中所说的那样,我们能够从变量開始从右往左读,q前面首先是const。

所以q自己的值是不变的。

再往做是 int*,因此q就是一个指向int类型的const变量。由于q本身是const的,所以它的值不能改变,始终指向变量a。

总之。说究竟还是开头说过的那句话,const类型变量的核心原则是它的值不能改变。仅仅要以此进行推断。无论是references to const 。pointers to const,consts pointer,还是const赋值给nonconst,nonconst赋值给const,我想都不是问题啦!

C++ 中的 const 类型变量的更多相关文章

  1. C与C++中的const

    同样,有下面一段代码: #include <iostream> using namespace std; int main() { ; int *j = (int *) &i; * ...

  2. const类型变量的详细解读

    const类型变量--------------------------------------int i;const int *p; --------------------------------- ...

  3. C++中的const

    一,C++中const的基本知识 1.C++中const的基本概念 1.const是定义常量的关键字,表示只读,不可以修改. 2.const在定义常量的时候必须要初始化,否则报错,因为常量无法修改,只 ...

  4. C++中的const关键字

    http://blog.csdn.net/eric_jo/article/details/4138548 C++中的const关键字的用法非常灵活,而使用const将大大改善程序的健壮性,本人根据各方 ...

  5. C++中关于const的思考

    在学习C++的过程中,经常被什么时候使用const.为什么使用const以及怎么使用const关键字这样的问题所困扰,以下是我对const的使用总结. 1.值替代 使用#define的确单缺点,第一: ...

  6. C++中加const与不加const的区别

    “常量”与“只读变量”的区别. 常量肯定是只读的,例如5, "abc",等,肯定是只读的,因为常量是被编译器放在内存中的只读区域,当然也就不能够去修改它. “只读变量”则是在内存中 ...

  7. C++笔记019:C++中的const修饰的是一个真正的常量

    原创笔记,转载请注明出处! 点击[关注],关注也是一种美德~ 程序一: 我们知道数组的下标不能为变量,必须是一个确定的值.在C语言中看程序: #define a 10 int main() { //第 ...

  8. C++中的const总结

    CONST 一.符号常量 声明: const 类型说明符 常量名 = 常量值: const float PI = 3.1415927; //可以交换const与float的位置 符号常量在声明时一定要 ...

  9. C和C++ 中的const

    C++中的const正常情况下是看成编译期的常量,编译器并不为const分配空间,只是在编译的时候将期值保存在名字表中,并在适当的时候折合在代码中.所以,以下代码: #include <iost ...

随机推荐

  1. django 简单会议室预约(4)

    基本的配置已经完成了,来看看最重要的views.py 先看看简单的注册登录功能,在django里有一个专门的模块用来验证用户信息 :所以只需要调用就好了: #-*-coding:utf-8 -*- f ...

  2. selenium+python自动化处理时间控件

    尝试编写12306网站查询余票信息的自动化脚本时,碰到日期选择的问题,此处做一下记录:

  3. ListCtrl添加右键菜单(ListCtrl类里编辑,给ListCtrl 发送NM_RCLICK消息)

    在开发中会用到右键菜单,我们来一起学习一下. 假如,我们现在已经准备好了列表,就差右键处理了. 1.在资源视图中的添加一个MENU,如图 2.给要添加右键菜单的ListCtrl子类,添加消息 按 ct ...

  4. bitmap2drawable-两者的转化实现

    先来看今天遇到的一个问题,是关于mms报错的.后来发现报的地方如下 Bitmap deleteBitMap = ((BitmapDrawable)mChipDelete).getBitmap(); D ...

  5. HTML基础第十一讲---背景标志

    转自:https://i.cnblogs.com/posts?categoryid=1121494 您是否老觉得网页「空空的」,没错!一个可能是我们还没有很多内容,另一个可能则是我们还没有设定网页背景 ...

  6. PDF.Js的使用—javascript中前端显示pdf文件

    PDF.Js的使用—javascript中前端显示pdf文件 写于2018/12/6 起因是一个图片展示页面需要展示pdf格式的文件,所以查了半天决定使用pdf.js,我也不求有多了解它,能实现我想要 ...

  7. 最大似然 vs. 最小二乘

    有一篇是比较最大似然估计和最小二乘法的: http://www.cnblogs.com/hxsyl/p/5590358.html 最大似然估计:现在已经拿到了很多个样本(你的数据集中所有因变量),这些 ...

  8. 基于ContentObserver来动态取消或加入屏幕超时任务

    前面也说了.ContentObserver能够来监控数据库里某一项数据的变化,当然也能够同一时候监控多个数据项的变化. 笔者在项目中须要改动到屏幕超时的需求,比方在车载业务中,倒车事件发生的时候,是不 ...

  9. js进阶 14-6 $.ajax()方法如何使用

    js进阶 14-6 $.ajax()方法如何使用 一.总结 一句话总结:$.ajax([settings])settings可选.用于配置Ajax请求的键值对集合. 1.$.ajax()的特点是什么( ...

  10. JS学习笔记 - fgm练习 2-11- 改变图片路径 var img = new Image(); 图片预加载

    <style> *{ margin: 0;padding: 0; list-style: none; } body{ background: black; } .outer{ margin ...