Const 重载解析

1. Const重载应用场景

首先,对于函数值传递的情况,因为参数传递是通过复制实参创建一个临时变量传递进函数的,函数内只能改变临时变量,但无法改变实参。则这个时候无论加不加const对实参不会产生任何影响。但是在引用或指针传递函数调用中,因为传进去的是一个引用或指针,这样函数内部可以改变引用或指针所指向的变量,这时const 才是实实在在地保护了实参所指向的变量。因为在编译阶段编译器对调用函数的选择是根据实参进行的,所以,只有引用传递和指针传递可以用是否加const来重载。

例如:

 1 int main()  
 2 {  
 3     const int b =5;  
 4     int c = 3;  
 5     A a;  
 6     a.foo(&b);  
 7     a.foo(&c);  
 8     return 1;  
 9 }  
10 
11 int main()  
12 {  
13     const int b =5;  
14     int c = 3;  
15     A a;  
16     a.foo(&b);  
17     a.foo(&c);  
18     return 1;  
19 }  

2. Const成员函数的重载

const 成员函数重载的解析和const参数重载解析的原理可以说是一样的。之所以这样说是因为const成员函数的解析可被看做是对函数this参数用const来修饰的过程

例如:

class A{  
public:  
    A();  
    int foo(int *test); //可看做:int foo(A *this,int *test);  
    int foo(int *test) const;//可看做:int foo(const A *this,int *test);  
};  

int main()  
{  
    int b = 5;  
    const A a;  
    a.foo(&b);  
    return 1;  
}  

  

3. 总结

(1) const重载主要是通过能否对传入的参数进行修改为判断的。

(2) const参数重载和const函数重载机制都是一样的,因为对于const 函数重载可看做是对隐含的指针this的参数重载。对于非成员函数,因为没有this指针,不能根据const重载。

(3) 重载是在编译阶段已经完成,对于汇编和链接来说透明的。

(4) 构造函数可以重载,但是不可以声明成const函数(需要初始化成员变量); 析构函数不传入参数也不返回值,因此不能重载。

原文地址:https://www.cnblogs.com/DF11G/p/4031238.html