• 先说说我对编译器对const处理的理解:const修饰符定义一个常量,const变量在整个程序中只有一个拷贝。编译器会跟踪所有用到这个常量的地方,一旦发现任何一个操作可能会改变这个它是常量这个属性,那么这个操作就是不合法的:
        const int val =10;
        int* pTemp=&val;              //不合法,因为用户可能试图通过pTemp指针改变val这个常量的值,这样就改变了val是一个常量的属性

    当对指针或者引用使用const修饰符的时候,根据const的位置有俩种不同的含义:
    1 当const在类型名前,表示指针或者引用所指向的值不能通过间接引用指针或者通过引用来改变
      const int val = 10;
      const int *constp = &var;       //OK.但是*constp不能作为赋值运算的左操作数出现
      int* ptemp = constp;             //不合法,因为不能保证temp指针不会试图去修改它所指向的数据的值
      const int &constr = var ;       //OK.但是constr不能作为赋值运算的左操作数
      int&  rtemp = val;              //不合法,因为val是常量,而rtemp不能保证不会试图修改val的值
      在这里。修改变量val的值是不合法的,因为val已经声明为常量。间接的修改也是不合法的,者并不是因为val是常量,而是因为指针(或引用)变量定义为指向常量。对于指向常量的指针或者引用,间接的修改时不合法的,即使它指向一个非常量的值,例如:
      int val = 10;
      const int *constp =&val;        //*constp任然不能作为赋值运算的左操作数出现
      const int &constr = val;        //constr 不能作为赋值运算的左操作数出现

    2 当const在类型名后指针名之前出现,表示指针式常量,它可以被间接引用,它所指向的数据的值可以改变,但是指针所指向的地址不能改变,这类指针应该在定义时初始化,因为如果在定义时没有初始化,那么这个指针就会毫无意义,因为以后再也不能赋值了。
       int val =10;                 
       int *const constp=&val;         //val变量的地址值将伴随整个constp的生命周期
       *constp = 20;                   //合法的,constp所指的数据的值可以改变
       constp=NULL                    //语法错误,因为指针是常量,它做指向的地址不能改变

    int* pTemp = constp;            //合法的,都可以间接修改变量的值。

    const在函数声明中的应用
       const对函数的返回值以及参数的修饰作用可以参考上面的内容。
       在类中声明的const成员变量,只能通过类构造函数的成员初始化列表初始化:具体可参看成员初始化列表和构造函数体类初始化的不同
       const类型的类对象只能调用const成员函数

    在类成员函数常见到const用在参数列表后函数体前
       这种情况下 该成员函数的生命和定义中都要使用这个const;
       这样的成员函数不能修改类的数据成员不能在函数中调用其它的非const成员函数

    主要是看core c++一书的笔记和自己后来的部分总结  由于水平有限  错误在所难免 请不吝指正

  • " src="http://student.csdn.net/ucenter/data/avatar/000/03/91/02_avatar_small.jpg" />

    回复#1

    韩卫平(C/C++老师) 2009-04-27 21:37

    写的不错
    还应加加一点 const &可以引用一个临时变量。生存周期同变量周期
    const int& x = 1;合法
    int& x = 1;不合法

  • 回复#2

    李羽 2009-04-27 21:41

    韩卫平(C/C++老师): 写的不错
    还应加加一点 const &可以引用一个临时变量。生存周期同变量周期
    const int& x = 1;合法
    int& x = 1;不合法

    谢谢韩老师指出不足
    学习了  去试试

  • 回复#3

    南昌大学 梁乃华(C/C++学生) 2009-04-28 22:29

    int val = 10;
      const int *constp =&val;        //*constp任然不能作为赋值运算的右操作数出现
      const int &constr = val;        //constr 不能作为赋值运算的右操作数出现
    疑问?*constp任然不能作为赋值运算的右操作数出现。constr 不能作为赋值运算的右操作数出现.
    它们不可以作为赋值运算的右操作数出现??
    我用vc6.0,试了一下,编译是通过的。在我用它们为左值的时候才报错。

  • 回复#4

    李羽 2009-04-29 09:26

    对不起 写错 确实是左操作数   因为作为右操作数是不会改变改变val的值的    对不起

  • " src="http://student.csdn.net/ucenter/data/avatar/000/03/90/28_avatar_small.jpg" />

    回复#5

    普罗通信西安有限公司 肖舸(C/C++老师) 2009-04-29 12:02

    写得好,我加精了。呵呵。

  • 回复#6

    李羽 2009-04-29 13:37

    普罗通信西安有限公司 肖舸(C/C++老师): 写得好,我加精了。呵呵。

    谢谢 肖老师   嘿嘿

  • 回复#7

    CAS 吕泰昌(C/C++学生) 2009-12-05 13:53

    const关键字在C语言中的作用仅仅是限定 不可以通过const变量来修改内存数据,但是可以通过别的方式,例如指针指向const变量然后再修改内存中的值。
    但对于const关键字的优化gcc和g++的处理还有些不一样(以下对C/C++的描述可缩小范围为gcc/g++的描述)。
    例如以下代码:
    Code:
       1. #include   
       2.   
       3. int main()  
       4. {  
       5.     const int a = 100;  
       6.     int *p = (int *)&a;  
       7.     (*p)=1;  
       8.     printf("%d",a);  
       9.     return 0;  
      10. }   
    在gcc下编译运行通过,输出1。
    在g++下编译运行通过,输出100。调试过程中发现在printf("%d",a);这句的时候没有从内存中读取a的值,而是直接用100这个字面常量。这就是const关键字优化的结果,如果定义的时候换成volatile const int a = 100; 用volatile关键字限定的话就输出的1。
    但是使用O2开关优化的时候,采用gcc/g++ (GCC) 3.4.5 (mingw-vista special)时,无论gcc还是g++都是输出100,加了volatile关键字也不起作用了。在gcc/g++ (GCC) 4.3.2 20081105 (Red Hat 4.3.2-7)中只要加入volatile,输出就是1。看来不同版本的编译器,不同的系统还有不一致的情况。所以这个结果提醒我们,不要试图修改const变量值,保不准会出现什么问题。
    http://student.csdn.net/space.php?uid=53444&do=blog&id=17766

  • 回复#8

    华南理工大学 刘雪赟(Java学生) 2009-12-05 17:20

    学到了很多,谢谢啦

  • 回复#9

    南昌大学 陈旁(C/C++学生) 2009-12-05 22:42

    const int a=5,
    int Arry[a]={1,2,3,4,5};如果去掉const,会出错,为什么啊?

  • 回复#10

    CAS 吕泰昌(C/C++学生) 2009-12-06 07:42

    南昌大学 陈旁(C/C++学生): const int a=5,
    int Arry[a]={1,2,3,4,5};如果去掉const,会出错,为什么啊?

    C99标准规定了,可以使用变量表达式作为数组下标,这种数组叫做可变长数组。但是大多数编译器不支持这个特性,GCC支持了,不过跟C99还有点不一样。
    但是你用const限定之后就是常量表达式,对这个支持的编译器还是很多的。
    下面的代码在gcc/g++ (GCC) 3.4.5 (mingw-vista special) 中可用,输出结果是404
    #include
    int main()
    {
            int a = 100;
            int b[++a];
            printf("%d",sizeof(b));
            return 0;
    }

  • 回复#11

    南昌大学 陈旁(C/C++学生) 2009-12-06 22:45

    CAS 吕泰昌(C/C++学生): C99标准规定了,可以使用变量表达式作为数组下标,这种数组叫做可变长数组。但是大多数编译器不支持这个特性,GCC支持了,不过跟C99还有点不一样。
    但是你用const限定之

我对const修饰符应用的理解相关推荐

  1. C语言-指针-基础用法、运算、指针与数组、指针数组、多级指针、void指针和const修饰符-学习笔记08

    文章目录 1. 地址和变量 2. 指针 2.1 基本声明 2.2 指针的目标 3. 指针的运算 3.1 指针的赋值运算 3.2 指针的算术运算 3.2.1 指针与常量的加法与减法 3.2.2 两指针相 ...

  2. C++ const修饰符和指针

    C++ const修饰符和指针 开发工具与关键技术:C++.VisualStudio 作者:何任贤 撰写时间:2019年04月10日 const修饰符,是用来修饰变量,被const修饰符,修饰过的变量 ...

  3. [vue] 说说你对vue的表单修饰符.lazy的理解

    [vue] 说说你对vue的表单修饰符.lazy的理解 input标签v-model用lazy修饰之后,vue并不会立即监听input Value的改变,会在input失去焦点之后,才会触发input ...

  4. [Reprint]C++函数前和函数后加const修饰符区别

    c++中关于const的用法有很多,const既可以修饰变量,也可以函数,不同的环境下,是有不同的含义.今天来讲讲const加在函数前和函数后面的区别.比如: 01 #include<iostr ...

  5. 访问修饰符的个人理解-private与protected

    一:private                             private --只有在声明它的类或结构中访问. 例: public class A {   private string ...

  6. 代码块、final关键字、包、权限修饰符的复习理解

    1.代码块: 概述:被大括号单独包裹的代码段叫做代码块根据位置的不同,命名的不同它的使用时机和功能不一样. 分类: 1.局部代码块: 概述:定义在方法中的代码块 位置:方法的方法体中 作用:给局部变量 ...

  7. 访问修饰符的真正理解

    首先,必须明确Java中类成员的访问修饰符(public.private.protect.默认或friendly等,C++也同理),并不能简单的理解为书上说的如"子类可以访问",具 ...

  8. const修饰符的用法总结

    一.const常量 在 C++ 中,有两种简单的定义常量的方式: 1.使用 #define 预处理器. #define LENGTH 10 #define WIDTH 5 #define NEWLIN ...

  9. C++成员函数中的const修饰符

    在一些C++源码中经常见到const修饰的函数,这里的const与放的位置无关,也就是下面三种写法是等效的,只不过通常使用第一种写法,可以编写函数进行测试,这里的const虽然写在了函数的位置,其实是 ...

最新文章

  1. ReentrantLock和synchronized两种锁定机制
  2. leetcode 231. Power of Two
  3. Linux脚本让我选择文件,linux – 用于选择文件和打印文件大小的Awk脚本
  4. nodejs 实现抓取数据
  5. how is view embedded via component usage being initialized
  6. C#设计模式之16-迭代器模式
  7. 引用管理器没有程序集_程序员必背英语单词不会,就别说你是程序员!
  8. mysql 利用触发器(Trigger)让代码更简单
  9. 为你的平面海报设计提供灵感和思路
  10. CSS中选择器的优先级 ( ※关于相同属性的覆盖问题 )
  11. HTML/CSS/js 日期等其他函数 相关收藏
  12. 黑群晖linux删除文件夹命令,手把手教你黑群晖(二)
  13. HTTP协议中URI和URL的区别
  14. 20155313 杨瀚 《网络对抗技术》实验四 恶意代码分析
  15. python小论文范文3000字_论文范文3000字
  16. 笔迹心理学(2): 功能设计
  17. xp系统IIS服务器,Windows XP系统如何开启IIS服务
  18. 【毕业设计】单片机与NBIOT通信模块 - 单片机 物联网 stm32
  19. 内网实现电视盒子访问PC
  20. 看完就懂——MySQL索引、事务与存储引擎

热门文章

  1. 求素数的几种方法(通俗易懂)
  2. 求质数(素数)的函数
  3. 升级打怪-精度图解HTTP(第六章)
  4. “做一名新手妈妈可比技术开发难多了。” | 母亲节专题
  5. 一文弄懂react-router V5的使用
  6. 微信小程序开发学习1(小程序的入门知识)
  7. Pytrhon编程快速上手-1.8习题
  8. swagger接口文档分组
  9. 确认个人电脑外网ip,并设置阿里云服务器只允许该ip访问
  10. ios 真机调试遇到的图片问题汇总