const 参数重载与const 成员函数重载

本文探讨了C++中const参数重载与const成员函数重载的原理,解释了如何利用const来区分重载函数,并介绍了const在函数重载中的作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

const 参数重载

《C++ primer》一书中这样描述:“可基于函数的引用形参是指向 const 对象还是指向非 const 对象,实现函数重载。将引用形参定义为 const 来重载函数是合法的,因为编译器可以根据实参是否为 const 确定调用哪一个函数。”

但是这一段描述并没有给出引用、指针和值传递前加const的实质区别是什么。在用非const的指针,引用和值均可转化为const的。
对于函数值传递的情况,因为参数传递是通过复制实参创建一个临时变量传递进函数的,函数内只能改变临时变量,但无法改变实参。则这个时候无论加不加const对实参不会产生任何影响。但是在引用或指针传递函数调用中,因为传进去的是一个引用或指针,这样函数内部可以改变引用或指针所指向的变量,这时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);  
};  
A::A(){  
}  
int A::foo(int *test){  
    std::cout << *test << "foo" <<std::endl;  
    return 1;  
}  
int A::foo(int *test) const {  
    std::cout << *test << "foo const" <<std::endl;  
    return 1;  
}  
int main()  
{  
    int b = 5;  
    const A a;  
    a.foo(&b);  //调用的是int foo(int *test) const;
    return 1;  
}  

总结:

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

  2. const参数重载和const函数重载机制都是一样的,因为对于const 函数重载可看做是对隐含的指针this的参数重载

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值