转换函数与explicit

本文通过示例介绍了C++中explicit关键字的作用,它用于消除隐式类型转换可能导致的歧义。在类Fraction中,转换构造函数和操作符double()导致了类型转换的冲突。当不使用explicit时,编译器会尝试多种转换路径,产生错误。通过使用explicit,可以明确指定类型转换,避免潜在问题。
摘要由CSDN通过智能技术生成

简介:

转换函数分为两类,一种是转出,把自己转换成别的类型,一种是转入,把别人转成自己类型,当两种都存在时,就可能会有歧义,造成编译器无法识别,这时候就需要explicit关键字。

测试代码:

先看类的结构:

class Fraction {
public:
    Fraction(int num, int den = 1) : m_num(num), m_den(den) {  //转入
        std::cout << "constructor funtion have called" << std::endl;
    }
    operator double() const {  //转出
        std::cout << "operator funtion have called" << std::endl;
        return ((double)m_num / m_den);
    }
    Fraction operator+(const Fraction& f) {
        this->m_num += f.m_num;
        this->m_den += f.m_den;
        return *this;
    }
    void printf() {
        std::cout << m_num << "\t"  << m_den <<std::endl;
    }
private:
    int m_num;
    int m_den;
};

调用类1:

int main() {
    Fraction fun(3, 5);
    double d = fun + 4;
    std::cout << d << std::endl;
    return 0;
}

运行结果如下:

可以看到对象fun调用了重载函数,转换成了double类型。

调用类2:

int main() {
    Fraction fun(3, 5);
    Fraction d = fun + 4;
    d.printf();
    return 0;
}

此时需要注释掉Fraction类的operator double()方法,运行结果如下:

可以看到int类型的4,调用了Fraction的构造函数,转成了Fraction类型;

然后恢复掉Fraction的operator double()方法,编译时就会报错,程序有歧义,把构造函数加上explicit关键字后,就会报错conversion from ‘double’ to non-scalar type ‘Fraction’。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值