} } }

    C++ const 的周全总结

    添加时间:2013-7-31 点击量:

    C++中的const关键字的用法很是灵活,而应用const将大大改良法度的结实性,本人按照各方面查到的材料进行总结如下,期望对伴侣们有所帮助。

    Const 是C++中常用的类型润饰符,常类型是指应用类型润饰符const申明的类型,常类型的变量或对象的值是不克不及被更新的。

    No.

    感化

    申明

    参考代码

    1

    可以定义const常量

    const int Max = 100;

    2

    便于进行类型搜检

    const常量稀有据类型,而宏常量没稀有据类型。编译器可以对前者进行类型安然搜检,而对后者只进行字符调换,没有类型安然搜检,并且在字符调换时可能会产生料想不到的错误

    void f(const int i) { .........}
    //对传入的参数进行类型搜检,不匹配进行提示

    3

    可以保护被润饰的器材

    防止不测的批改,加强法度的结实性。

    void f(const int i) { i=10;//error! }
    //若是在函数体内批改了i,编译器就会报错

    4

    可以很便利地进行参数的调剂和批改

    同宏定义一样,可以做到不变则已,一变都变

    5

    为函数重载供给了一个参考

    class A
    {
    ......
    void f(int i) {......} //一个函数
    void f(int i) const {......} //上一个函数的重载
    ......
    };

    6

    可以节俭空间,避免不须要的内存分派

    const定义常量从汇编的角度来看,只是给出了对应的内存地址,而不是象#define一样给出的是立即数,所以,const定义的常量在法度运行过程中只有一份拷贝,而#define定义的常量在内存中有若干个拷贝

    #define PI 3.14159 //常量宏
    const doulbe Pi=3.14159; //此时并未将Pi放入ROM中
    ......
    double i=Pi; //此时为Pi分派内存,今后不再分派!
    double I=PI; //编译时代进行宏调换,分派内存
    double j=Pi; //没有内存分派
    double J=PI; //再进行宏调换,又一次分派内存!

    7

    进步了效力

    编译器凡是不为通俗const常量分派存储空间,而是将它们保存在符号表中,这使得它成为一个编译时代的常量,没有了存储与读内存的操纵,使得它的效力也很高

    int const p =&a; //等价const int p =&a;   //指针所指值是常量 , p可以批改
    

    int const p ; //指针是常量,所指向的值可以批改
     

    class WORK
    
    {
    public:
    const int NUM;
    int a;
    WORK():NUM(
    3//const var must init in init_list
    {
    a
    =1;
    }
    void change()
    {
    a
    =2;
    }
    void disp()const
    {
    cout
    <<const NUM=<<NUM<<endl;
    //change(); //const function can not call non_function
    //a=3; const function can not modify member variable
    }
    };
    我俩之间有着强烈的吸引力。短短几个小时后,我俩已经明白:我们的心是一个整体的两半,我俩的心灵是孪生兄妹,是知己。她让我感到更有活力,更完美,更幸福。即使她不在我身边,我依然还是感到幸福,因为她总是以这样或者那样的方式出现在我心头。——恩里克·巴里奥斯《爱的文明》
    分享到: