C++primer 7.5.4节练习

本文详细解析了C++中构造函数的使用场景,包括explicit关键字的作用及其对构造函数行为的影响,探讨了不同类型转换的实现方式及其后果。

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

练习7.47

视情况而定,如果需要保证数据的安全性和正确性,可以用explicit修饰来抑制构造函数定义的隐式转换,而如果为了程序的灵活性而言,使用explicit大大降低了程序的灵活,故实际情况中需要仔细斟酌;

练习7.48

第二句调用了使用一个string实参的构造函数来构造对象;

第三句,是首先将字符串常量值隐式转换为string类型,在构造新对象;

如果是explicit

第一个直接初始化合法;

则第二个构造不合法;

练习7.49

a和b都是实现了s从string型隐式转换成Sales_data类型的,区别在于a转换后返回的是临时量的副本,而b是临时量的引用;

c则是s是const Sales_data&的,调用后,s值不会发生改变

(这里需要验证一下)

练习7.50

见最终版本

练习7.51

接受一个单参数的const char*的string构造函数不是explicit的,而接受一个容量参数的vector构造函数是explicit的

原因在于vector在声明时需要指定其中的元素类型,不存在需要隐式转换的必要,而string则不然,他需要隐式转换来将各种能够转换的类型转换为const char*。

网友答案:vector是一个容器,必须指定容器里装的对象类型,如vector<char>是一个新的类型,如果通过char类型转换为vector<char>,则vector的灵活性受到影响,具体来说,vector<char>可以push_back是char的类型,vector各个函数的调用很方便,如果通过类类型转换,反而使得vector的使用受限,string类型不是explicit,string类型可以自然接收不同类类型的转换,支持隐式转换使得跟字符串的处理变得灵活。

 

转载于:https://www.cnblogs.com/wuyinfenghappy/p/7301359.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值