const指南

基本词义 

意思就就是说利用const进行修饰的变量的值在程序的任意位置将不能再被修改,就如同常数一样使用! 

使用方法

const int a=1;//这里定义了一个int类型的const常数变量a; 

但对于指针来说const仍然是起作用的,以下有两点要十分注意,因为下面的两个问题很容易混淆! 

我们来看一个如下的例子:

 //程序作者:管宁 

//站点:www.cndev-lab.com 

//所有稿件均有版权,如要转载,请务必著名出处和作者 

#include <iostream> 

using namespace std; 

void main(void) 

{ 

const int a=10; 

int b=20; 

const int *pi; 

pi=a; 

cout <<*pi << "|" << a <<endl; 

pi=b; 

cout <<*pi << "|" <<b <<endl; 

cin.get(); 

} 

上面的代码中最重要的一句是 const int *pi 

这句从右向左读作:

pi是一个指向int类型的,被定义成const的对象的指针; 

这样的一种声明方式的作用是可以修改pi这个指针所指向的内存地址却不能修改指向对象的值。 

  如果你在代码后加上*pi=10;这样的赋值操作是不被允许编译的!

请看如下的代码 

//程序作者:管宁 

//站点:www.cndev-lab.com 

//所有稿件均有版权,如要转载,请务必著名出处和作者 

#include <iostream> 

using namespace std; 

void main(void) 

{ 

int a=10; 

const int *const pi=a; 

cout <<*pi << "|" <<a <<endl; 

cin.get(); 

} 

上面的代码中最重要的一句是 const int *const pi 

这句从右向座读作:

pi是一个指向int类型对象的const指针; 

这样的一种声明方式的作用是你既不可以修改pi所指向对象的内存地址也不能利用指针的解引用方式修改对象的值; 

所以你如果在最后加上*pi=20,想试图通过这样的方式修改对象a的值是不被允许编译的! 

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 剑指OFFER之重建二叉树(九度OJ1385)

    题目描述: 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。例如输入前序遍历序列{1,2,4,7...

    用户1154259
  • (JAVA版)冒泡排序

    核心代码: public void bubbleSort(){ for(int i=0;i<length-1;i++){ ...

    用户1154259
  • 不相交集类

    等价关系:自反性,对称性,传递性 class DisjSets//不相交集的类架构 { public: explicit DisjSets(int nu...

    用户1154259
  • WPF popup置顶 另外的已知问题

    http://www.cnblogs.com/Leaco/p/3164394.html

    林德熙
  • 颜色空间系列4: RGB和YDbDr颜色空间的转换及优化算法

    颜色空间系列代码下载链接:http://files.cnblogs.com/Imageshop/ImageInfo.rar (同文章同步更新)

    用户1138785
  • LeetCode 870. 优势洗牌(贪心 & 二分查找)

    给定两个大小相等的数组 A 和 B,A 相对于 B 的优势可以用满足 A[i] > B[i] 的索引 i 的数目来描述。

    Michael阿明
  • 数据结构是哈希表(hashTable)(二)

    public class HashTableDouble { private DataItem[] hashArray; privat...

    Java帮帮
  • 线段树 BIT 求冒泡排序的交换次数

    线段树特别适合与区间相关的运算,比如MRQ(minimum range query)求一段区间内的最小值。 BIT可以看作是压缩了的线段树,由于(某类)线段树...

    kalifa_lau
  • LWC 56:718. Maximum Length of Repeated Subarray

    LWC 56:718. Maximum Length of Repeated Subarray 传送门:718. Maximum Length of Repea...

    用户1147447
  • HDU5972Regular Number(ShiftAnd算法 bitset)

    接下来\(n\)行,每行开头有一个整数\(num\)表示匹配串中该位置的字符可以在\(num\)个桅子花出现,接下来输入这\(num\)个位置

    attack

扫码关注云+社区

领取腾讯云代金券