zoukankan      html  css  js  c++  java
  • C++笔记16之const的用法总结

    const主要是为了程序的健壮型,减少程序出错.
    最基本的用法:

    1. const int a=100; b的内容不变,b只能是100也就是声明一个int类型的常量(#define b =100)  
    2. int const b=100; //和上面作用一样   

    const指针和引用一般用在函数的参数中

    1. int* m = &a; //出错,常量只能用常指针  
    2. int c= 1;const int*pc = &c;//常指针可指向常量   
    1. const int* pa = &a; //指针指向的内容为常量(就是b的值不变)  
    2. int const *a = &b; //指针指向的内容为常量(就是b的值不变)*p=3//error  
    3. int* const a = &b; //指针为常量,不能更改指针了如 a++但可以改值*p=3;  


    从这可以看出const放在*左侧修饰的是指针的内容,const放在*右侧修饰的是指针
    本身
    const引用的用法和指针一样

    1. int const & a=b; 和指针一样  
    2. const int& a=b; 和指针一样  

    但没有 int& const a=b 的用法因为引用不能做移位运算,但只是出个warning 

    const int* const a = &b; //综合应用,一般用来传递多维的数组
    类如:char* init[] = {"Paris","in the","Spring"};
    void fun(const int* const a){}
    fun(init)//保护参数不被修改 

    1. int A(int)const; //是常函数,只能用在类中,调用它的对象不能改改变成员值  
    2. const int A(); //返回的是常量,所以必须这么调用 const int a=A();  
    3. int A(const int); //参数不能改值,可用在任意函数  
    4. int A(const int*);  
    5. ....  
    6. int height() const;//常函数只能由常函数调用  
    7. int max(int,int) const;  
    8. int Max = max(height(),height());   


    1. const int* pHeap = new int;  
    2. delete pHeap;  
    3. p = NULL;//出错  

    我的解决办法是强制类型转换

    1. const int* pHeap = new int(1);  
    2. delete (int*)pHeap;  
    3. pHeap = NULL;   

    一、const 和引用联合使用的时候要注意 

    1. const int a = 1;   
    2. const int& ref1 = a;  
    3. const int& ref2 = 1;   

    ref1 和 ref2 都是正确的,但是他们引用的内容和一般的引用不同
     const int& ref1 = a; 而言,其实这个 ref1 已经和 a 没有任何关系了
    ref1 实际上是对一个临时量的引用。同理 const int& ref2 = 1; 也是对
    一个临时量做的引用。当引用临时量是 C++ 的隐式类型转换可以起作用。
    临时量的生存期和引用量的生存期相同。 

    二、强传const对象可能导致无定义行为 

    对于优化做的比较好的编译器,代码 const int i = 1;
    当后面用到变量 i 的时候,编译器会优化掉对 i 的存取,而直接使用立即数 1 

    const int i = 1; 

    *(const_cast<int*>(&i)) = 2;
    cout << *(int*)&i << endl;
    cout << i << endl; 

    所以,对 const 对象做 const_cast 可能导致无定义行为
    目前我就遇到这些问题,那位还有补充的吗 

    有哪些不对的地方,请大家指正。求交流。。。

  • 相关阅读:
    千万别用树套树 【题意:有多少线段完全覆盖某一线段【树状数组维护】】【模板题】
    Codeforces Round #590 (Div. 3)【D题:26棵树状数组维护字符出现次数】
    Codeforces Round #590 (Div. 3)【D题:维护26棵树状数组【好题】】
    Codeforces Round #350 (Div. 2) A B C D1 D2 水题【D2 【二分+枚举】好题】
    AtCoder Beginner Contest 142【D题】【判断素数的模板+求一个数的因子的模板】
    AtCoder Beginner Contest 116 D
    序列自动机【模板】
    题解 CF1428G Lucky Numbers (Easy Version and Hard Version)
    题解 CF1428F Fruit Sequences
    题解 P5401 [CTS2019]珍珠
  • 原文地址:https://www.cnblogs.com/zhaoxinshanwei/p/3857230.html
Copyright © 2011-2022 走看看