C++primer 7.5.4节练习

练习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类型可以自然接收不同类类型的转换,支持隐式转换使得跟字符串的处理变得灵活。

 

posted @ 2017-08-07 21:10  五月份小姐  阅读(349)  评论(0编辑  收藏  举报