C++ 隐式的类类型转换
2015-02-19 18:42
302 查看
如果构造函数只接受一个实参,则它实际上定义了转换为此类类型的隐式转换机制,有时我们把这种构造函数称作转换构造函数。
在Sales_data类中,接受string的构造函数和接受istream的构造函数分别定义了从这两种类型向Sales_data隐式转换的规则。也就是说,在需要使用Sales_data的地方,我们可以使用string或者istream作为代替:
string null_book = "9-999-99999-9";
item.combine(null_book);//combine的参数是一个Sales_data的常量引用,这里构造了一个临时的Sales_data对象
在这里我们用一个string实参调用了Sales_data的combine成员。该调用是合法的,编译器用给定的string自动创建了一个Sales_data对象。新生成的这个(临时)Sales_data对象被传递给combine。通过隐式类型转换产生的临时对象是无名的常量对象。因为combine的参数是一个常量引用,所以我们可以给该参数传递一个临时量。
只允许一步类类型转换
编译器只会自动地执行一步类型转换。例如,因为下面的代码隐式地使用了两种转换规则,所以它是错误的。
item.combine("9-999-99999-9");
item.combine(string("9-999-99999-9"));//正确:显式地转换成string,隐式地转换成Sales_data
item.combine(Sales_data("9-999-99999-9"));//正确:隐式地转换成string,显式地转换成Sales_data
在Sales_data类中,接受string的构造函数和接受istream的构造函数分别定义了从这两种类型向Sales_data隐式转换的规则。也就是说,在需要使用Sales_data的地方,我们可以使用string或者istream作为代替:
string null_book = "9-999-99999-9";
item.combine(null_book);//combine的参数是一个Sales_data的常量引用,这里构造了一个临时的Sales_data对象
在这里我们用一个string实参调用了Sales_data的combine成员。该调用是合法的,编译器用给定的string自动创建了一个Sales_data对象。新生成的这个(临时)Sales_data对象被传递给combine。通过隐式类型转换产生的临时对象是无名的常量对象。因为combine的参数是一个常量引用,所以我们可以给该参数传递一个临时量。
只允许一步类类型转换
编译器只会自动地执行一步类型转换。例如,因为下面的代码隐式地使用了两种转换规则,所以它是错误的。
item.combine("9-999-99999-9");
item.combine(string("9-999-99999-9"));//正确:显式地转换成string,隐式地转换成Sales_data
item.combine(Sales_data("9-999-99999-9"));//正确:隐式地转换成string,显式地转换成Sales_data
相关文章推荐
- C++ 隐式和显式 初始化,类型转换
- C++中显式和隐式初始化和类型转换
- C++隐式类类型转换(转)
- C++ 学习之构造函数:构造函数小结3 默认构造函数、隐式类型转换和复制构造函数
- c++ 类类型的隐式转换
- [C++再学习系列] 隐式类型转换与转换操作符operator T
- C++:显式和隐式初始化、显式和隐式类型转换
- [C++再学习系列] 隐式类型转换与转换操作符operator T
- C++ 学习之构造函数:构造函数小结3 默认构造函数、隐式类型转换和复制构造函数
- 从一道面试题看C++隐式类型转换
- 隐式类型转换c/c++
- [C++再学习系列] 隐式类型转换与转换操作符operator T
- 隐式类型转换(C++学习)
- c++隐式类型转换
- More Effective C++ 阅读笔记(四)-- 避免使用隐式类型转换
- C++类型隐式转换
- C++ 学习之构造函数:构造函数小结3 默认构造函数、隐式类型转换和复制构造函数
- c++中的explicit关键字及隐式类型转换
- 从一道面试题看C++隐式类型转换
- c++ 隐式类型转换