C++转换函数
2017-08-11 23:12
85 查看
一、conversion function, 转换函数
转换函数(conversion function)是一种特殊类型的类成员函数。它定义了一个由用户定义的转换,以便把一个类对象转换成某种其他的类型。 在类的声明中,通过指定关键字operator,并在其后加上转换的目标类型后,我们就可以声明转换函数。
1. 特点
转换函数采用如下的一般形式: operator type()
这里的type可用内置类型、类类型或typedef名取代。但是不允许type表示数组或函数。
转换函数必须是成员函数,它的声明不能指定返回类型和参数列表。
如果转换函数没有类成员进行修改,可以在函数声明中增加const关键字,增加代码的健壮性。
2. 例子
以下代码展示了类Fraction中的转换函数operator double() const。
class Fraction { public: Fraction(int num, int den) : m_numerator(num), m_denominator(den) {} operator double() const { return (double) (m_numerator / m_denominator); } private: int m_numerator; // 分子 int m_denominator; // 分母 }; Fraction f(3, 5); double d = 4 + f; // 调用operater double将f转换成double1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
3. 说明
double d = 4 + f;这一语句会首先查找Fraction是否有重载操作符 operator + (double, Fraction) 的函数,由于没有,所以调用会转换函数
operator double() const。
另外,转换函数除了可以将一个类型转换成另一个基本类型,还可以将一个类型转换成另一个复合类型(例如string类型)。
4. 作用
把这种东西(A)转换成别的东西(B)
二、non-explicit-one-argument constructor
1. 例子
class Fraction { Fraction(int num, int den=1) : m_numerator(num), m_denominator(den) {} Fraction operator + (const Fraction& f) { return Fraction(...); } private: int m_numerator; // 分子 int m_denominator; // 分母 }; Fraction f(3, 5); Fraction d2 = f + 4; // 调用non-explicit ctor将4转换成Fraction(4, 1),然后再调用operator +1
2
3
4
5
6
7
8
9
10
11
12
f959
13
14
15
16
17
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
2. 说明
构造函数虽然有two parameters(两个形参),但只有one argument,且构造函数前面没有explicit,所以叫做non-explicit-one-argument constructor。
3. 作用
把别的东西(B)转换成这种东西(A)
三、conversion function vs. non-explicit-one-argument constructor
1. 例子
class Fraction { Fraction(int num, int den=1) : m_numerator(num), m_denominator(den) {} operator double() const { return (double) (m_numerator / m_denominator); } Fraction operator + (const Fraction& f) { return Fraction(...); } private: int m_numerator; // 分子 int m_denominator; // 分母 }; Fraction f(3, 5); Fraction d2 = f + 4; // [Error] ambiguous1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
2. 说明
上述的代码会导致二义性的出现,即 - 可以将4转换成Fraction
- 可以将f转换成double,与4相加得到一个double,然后再转换成Fraction
为了使得编译通过,可以将
Fraction d2 = f + 4;改成
double d2 = f + 4;即可。
四、explicit-one-argument constructor
1. 例子
class Fraction { explicit Fraction(int num, int den=1) : m_numerator(num), m_denominator(den) {} operator double() const { return (double) (m_numerator / m_denominator); } Fraction operator + (const Fraction& f) { return Fraction(...); } private: int m_numerator; // 分子 int m_denominator; // 分母 }; Fraction f(3, 5); Fraction d2 = f + 4; // [Error] convertion from double to Fraction requested1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
2. 说明
由于在构造函数前面增加了explicit关键字,所以不能将4转换成Fraction类型;也不能先将f转换成double类型,与4相加后再将double转换成Fraction。
3. 作用
explicit这个关键字基本只出现在构造函数前面,意思是需要明确地需要调用这个构造函数才能调用,不存在暗中、自动的转换操作。
五、转换函数在STL中的运用
1. 例子
template<class Alloc> class vector<bool, Alloc> { public: typedef __bit_reference reference; protected: reference operator[] (size_type n) { return *(begin() + defference_type(n)); } }; struct __bit_reference { unsigned int *p; unsigned int mask; public: operator bool() const { return ! ( ! ( *p & mask) ); } };1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
2. 说明
class vector <bool, Alloc>这里是模板的偏特化。
reference operator[] (size_type n)返回vector元素的类型,从vector类型的声明看,应该是返回 一个bool类型的值,可是现在却返回了一个referecnce类型。
reference类型亦即__bit_reference类型,故__bit_reference类型需要转换成bool类型。
这样就要求__bit_reference类型需包含一个转换函数,可以将__bit_reference类型转换成bool类型,这正是转换函数
operator bool() const的作用。
参考资料
侯捷《C++最佳编程实践》视频,极客班,2015《C++ Primer》中文版,第三版,潘爱民等译,2002
转载:http://blog.csdn.net/lihao21
相关文章推荐
- c++转换函数和类的自动转换
- C++面向对象编程<十二>转换函数、explicit、class几种表现形式
- C++转换函数
- 一则C++Unicode集与多字节转换函数使用。
- C++中转换函数
- c++ gb2312 utf8 转换函数
- C++中 ,不存在从 "std::string" 到 "int" 的适当转换函数。
- [转] C++ 运算符重载 转换函数
- C/C++数据类型转换函数
- C/C++各种数字和字符串之间的转换函数
- C++定义隐式转换函数,将类转换为内部的一个成员变量
- C++之基本数据类型转换和转换函数
- C++主题——转换函数
- 王老师 C++ 运算符重载 转换函数 第一讲
- C++中使用类(重载,友元函数,转换函数等)
- c++里的转换函数
- C++主题——转换函数
- C++任意进制转任意进制的转换函数实现
- 王老师 C++ 运算符重载 转换函数 第二讲
- 【C++】UTF-8字符和GB2312字符相互转换函数