const 与重载

const到底是不是一个重载的参考对象,请看下面的例子

class A
{
public:
    void f(int i){ std::cout<<"1";}; //函数1
    void f(int i) const { std::cout<<"2" ;};//函数2

};

这个地方的重载是没有问题的,说明const 修饰函数能够区分重载

 

class B
{
    void f(int i);
    const void f(int i);

};

这次编译器会报出 'B::f' : redefinition; 的错误,说明const作为修饰返回值不能够区分重载

class C
{
    void f(int i);
    void f(const  int i);
};

这个是错误的,编译通不过。那么是不是说明内部参数的const不予重载呢?
再看下面的例子:

class D
{
public:
    void f(int &i) { std::cout<<"3";}; //函数3;
    void f(const  int &i){ std::cout<<"4" ;};//函数4
};

 这个程序是正确的,看来上面的结论是错误的。为什么会这样呢?这要涉及到
接口的透明度问题。按值传递时,对用户而言,这是透明的,用户不知道函数对形参
做了什么手脚,在这种情况下进行重载是没有意义的,所以规定不能重载!当指针或
引用被引入时,用户就会对函数的操作有了一定的了解,不再是透明的了,这时重载
是有意义的,所以规定可以重载。

返回值不能作为区分重载的条件。


现在来看一下成员 函数调用的情况:

A a;
a.f(1);

对于以上调用,如果函数1不存在就会调用函数2,如果函数1和函数2都存在,优先调用函数1.

const A a;
a.f(1);

却只能调用函数2,如果函数2不存在,将会报错。

int i = 0;
D d;
d.f(i);

以上调用既可以调用函数3也可以调用函数4,优先调用函数3.

const int i = 0;
D d;
d.f(i);

只能调用函数4,函数3存在函数4不存在,也不能调用函数3,直接报错

总结: const 对象只能调用const 方法,非const 对象既能调用const 方法也能调用非const方法,优先调用非const方法。

如果重载的函数都是引用或指针,const 变量 只能调用带有const 参数的方法,非const 变量既能调用带const 参数的方法,也能调用不带cosnt 参数的方法,优先调用不带const 参数的方法

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在C++中,运算符重载允许我们为类类型定义自定义的运算符行为。当我们使用const对象时,我们可以重载运算符以确保正确的行为。为了重载运算符并支持const对象,我们可以在成员函数声明和定义中使用const关键字来指示该函数不会修改对象的状态。 下面是一个示例,演示了如何重载二元运算符+并支持const对象: ```cpp class MyClass { public: int value; MyClass(int val) : value(val) {} MyClass operator+(const MyClass& other) const { return MyClass(value + other.value); } }; ``` 在上面的示例中,我们重载了+运算符来执行两个MyClass对象的相加操作。注意在成员函数声明和定义中,参数类型 MyClass& 之前加上了const关键字,表示该参数是一个常量引用,并且不会修改对象的状态。同时,返回值类型 MyClass 之前也加上了const关键字,以表示返回的对象也是一个常量对象。 这样,我们就可以在使用const MyClass对象时进行相加操作,例如: ```cpp const MyClass obj1(5); const MyClass obj2(10); MyClass result = obj1 + obj2; // 正确:const对象之间的相加操作 ``` 请注意,通过重载运算符实现的操作符重载const成员函数不同。通过const成员函数,我们可以在const对象上调用该函数,而不会修改对象的状态。而通过运算符重载,我们可以支持在const对象上执行运算符操作,但是返回的结果对象不会是const对象。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值