C++-explicit关键字

本文探讨了C++中构造函数的explicit关键字使用,解释了如何避免因单参数构造函数引起的隐式类型转换,从而增强类型安全性。通过具体代码示例,说明了explicit关键字如何阻止不必要的类型转换,减少潜在的编程错误。

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

C++中可以将构造函数声明为explicit型,以避免后台类型转换(behind-the-scenes tyoe conversions)
我们先来看这样一个模拟int的类

class IntCell {
public:
    // 默认的无参构造函数
    IntCell() {
        storedValue = 0;
    }
    // 含参构造函数
    IntCell(int initialValue) {
        storedValue = initialValue;
    }
    // 返回存储的值
    int read() {
        return storedValue;
    }
    // 修改存储的值
    void write(int num) {
        storedValue = num;
    }
priavet:
    int storedValue;
}

在C++中,默认允许隐式类型转换(implicit type conversion),但这破坏了强类型化(strong typing),可能导致一些难以发现的bug。考虑以下的代码:

IntCell obj;
obj = 37; // 本不应编译,类型不匹配

上述代码中执行了一个intIntCell的赋值语句。从强类型化的角度出发,我们希望他是不成立的,因为等式两边类型不匹配,应该调用obj的write方法取代他。
但是,在正常情况下,这个等式是成立的。
为什么呢?单参数的构造函数会定义一个隐式类型转换(implicit type conversion),创建一个临时对象,这个对象令这样的赋值兼容。实际上,obj = 37;这一语句等价于以下的代码

IntCell temp = 37;
obj = temp;

转载于:https://www.cnblogs.com/Bylight/p/10529895.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值