C++转换构造函数和类型转换函数

今天是第一次听到C++还有个转换构造函数,之前经常见到默认构造函数、拷贝构造函数、析构函数,但是从没听说过转换构造函数,隐式转换函数也是一样,C++的确是够博大精深的,再次叹服!

         其实我们已经在C/C++中见到过多次标准类型数据间的转换方式了,这种形式用于在程序中将一种指定的数据转换成另一指定的类型,也即是强制转换,比如:int a = int(1.23),其作用是将1.23转换为整形1。然而对于用户自定义的类类型,编译系统并不知道如何进行转换,所以需要定义专门的函数来告诉编译系统改如何转换,这就是转换构造函数和类型转换函数!


一、转换构造函数


        转换构造函数(conversion constructor function) 的作用是将一个其他类型的数据转换成一个类的对象。
        当一个构造函数只有一个参数,而且该参数又不是本类的const引用时,这种构造函数称为转换构造函数。
        转换构造函数是对构造函数的重载。
        例如:

[cpp]  view plain  copy
 print ?
  1. Complex(double r)   
  2. {  
  3.     real=r;  
  4.     imag=0;  
  5. }  
        其作用是将double型的参数r转换成Complex类的对象,将r作为复数的实部,虚部为0。用户可以根据需要定义转换构造函数,在函数体中告诉编译系统怎样去进行转换。
        那么如何使用转换构造函数进行类型转换呢?我们看如下的例子:

[cpp]  view plain  copy
 print ?
  1. // TypeSwitch.cpp : 定义控制台应用程序的入口点。  
  2. //  
  3.   
  4. #include "stdafx.h"  
  5. #include <iostream>  
  6.   
  7. using namespace std;  
  8.   
  9. class Complex  
  10. {  
  11. public:  
  12.     Complex():real(0),imag(0){};  
  13.     Complex(double r, double i):real(r),imag(i){};  
  14.     Complex(double r):real(r),imag(0){};  // 定义转换构造函数  
  15.   
  16.     void Print(){  
  17.         cout<<"real = " << real <<" image = "<<imag<<endl;  
  18.     }  
  19.     Complex& operator+(Complex c){  
  20.         return Complex(this->real + c.real, this->imag + c.imag);       
  21.     }  
  22. private:  
  23.     double real;  
  24.     double imag;  
  25. };  
  26.   
  27. int main(int argc, _TCHAR* argv[])  
  28. {  
  29.     Complex c;  
  30.     c = 1.2;  // 调用转换构造函数将1.2转换为Complex类型  
  31.     c.Print();  
  32.     Complex c1(2.9, 4.2);  
  33.     Complex c2 = c1 + 3.1; // 调用转换构造函数将3.1转换为Complex类型  
  34.     c2.Print();  
  35.     return 0;  
  36. }  
        不仅可以将一个标准类型数据转换成类对象,也可以将另一个类的对象转换成转换构造函数所在的类对象。如可以将一个学生类对象转换为教师类对象,可以在Teacher类中写出下面的转换构造函数:
[cpp]  view plain  copy
 print ?
  1. Teacher(Student& s)  
  2. {  
  3.     num=s.num;  
  4.     strcpy(name,s.name);  
  5.     sex=s.sex;  
  6. }  
        使用方法同上!
        注意:

        1.用转换构造函数可以将一个指定类型的数据转换为类的对象。但是不能反过来将一个类的对象转换为一个其他类型的数据(例如将一个Complex类对象转换成double类型数据)。

        2.如果不想让转换构造函数生效,也就是拒绝其它类型通过转换构造函数转换为本类型,可以在转换构造函数前面加上explicit!例如:

[cpp]  view plain  copy
 print ?
  1. // TypeSwitch.cpp : 定义控制台应用程序的入口点。  
  2. //  
  3.   
  4. #include "stdafx.h"  
  5. #include <iostream>  
  6.   
  7. using namespace std;  
  8.   
  9. class Complex  
  10. {  
  11. public:  
  12.     Complex():real(0),imag(0){};  
  13.     Complex(double r, double i):real(r),imag(i){};  
  14.     explicit Complex(double r):real(r),imag(0){};  // explicit禁止构造函数的转换功能  
  15.   
  16.     void Print(){  
  17.         cout<<"real = " << real <<" image = "<<imag<<endl;  
  18.     }  
  19. private:  
  20.     double real;  
  21.     double imag;  
  22. };  
  23.   
  24. int main(int argc, _TCHAR* argv[])  
  25. {  
  26.     Complex c1(1.2, 2.3), c2;  
  27.     double d;  
  28.     d = c1 + 1.1; // 调用类型转换函数将c1转换为double,编译出错!  
  29.     cout<<d<<endl;  
  30.       
  31.     return 0;  
  32. }  


二、类型转换函数


        用转换构造函数可以将一个指定类型的数据转换为类的对象。但是不能反过来将一个类的对象转换为一个其他类型的数据(例如将一个Complex类对象转换成double类型数据)。而类型转换函数就是专门用来解决这个问题的!
类型转换函数的作用是将一个类的对象转换成另一类型的数据。
        如果已声明了一个Complex类,可以在Complex类中这样定义类型转换函数:

[cpp]  view plain  copy
 print ?
  1. operator double( )  
  2. {  
  3.      return real;  
  4. }  

        类型转换函数的一般形式为:

        operator 类型名( )
        {
               实现转换的语句
        }

        注意事项:
        1.在函数名前面不能指定函数类型,函数没有参数。
        2.其返回值的类型是由函数名中指定的类型名来确定的。
        3.类型转换函数只能作为成员函数,因为转换的主体是本类的对象,不能作为友元函数或普通函数。
        4.从函数形式可以看到,它与运算符重载函数相似,都是用关键字operator开头,只是被重载的是类型名。double类型经过重载后,除了原有的含义外,还获得新的含义(将一个Complex类对象转换为double类型数据,并指定了转换方法)。这样,编译系统不仅能识别原有的double型数据,而且还会把Complex类对象作为double型数据处理。

[cpp]  view plain  copy
 print ?
  1. // TypeSwitch.cpp : 定义控制台应用程序的入口点。  
  2. //  
  3.   
  4. #include "stdafx.h"  
  5. #include <iostream>  
  6.   
  7. using namespace std;  
  8.   
  9. class Complex  
  10. {  
  11. public:  
  12.     Complex():real(0),imag(0){};  
  13.     Complex(double r, double i):real(r),imag(i){};  
  14.     Complex(double r):real(r),imag(0){};  // 定义转换构造函数  
  15.   
  16.     void Print(){  
  17.         cout<<"real = " << real <<" image = "<<imag<<endl;  
  18.     }  
  19.     operator double(){ // 定义类型转换函数  
  20.         return real;  
  21.     }  
  22. private:  
  23.     double real;  
  24.     double imag;  
  25. };  
  26.   
  27. int main(int argc, _TCHAR* argv[])  
  28. {  
  29.     Complex c1(1.2, 2.3);  
  30.     double d;  
  31.     d = c1 + 1.1; // 调用类型转换函数将c1转换为double  
  32.     cout<<d<<endl;  
  33.       
  34.     return 0;  
  35. }  
        本例中,对于d = c1 + 1.1;先调用类型转换函数将c1转为double类型,然后在与1.1相加!

        那么程序中的Complex类对具有双重身份,既是Complex类对象,又可作为double类型数据。Complex类对象只有在需要时才进行转换,要根据表达式的上下文来决定。转换构造函数和类型转换运算符有一个共同的功能: 当需要的时候,编译系统会自动调用这些函数,建立一个无名的临时对象(或临时变量)。

原文地址:http://blog.csdn.net/onejune2013/article/details/16803321

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
C++中的类型转换构造函数是一种特殊的构造函数,它允许将一个类型的对象转换为另一个类型的对象。类型转换构造函数通常用于实现隐式类型转换,使得在某些情况下可以自动地将一个类型转换为另一个类型。 下面是一个示例,演示了如何在C++中定义和使用类型转换构造函数: ```cpp #include <iostream> class MyInt { public: MyInt(int value) : m_value(value) {} // 类型转换构造函数 MyInt(double value) : m_value(static_cast<int>(value)) {} int getValue() const { return m_value; } private: int m_value; }; int main() { MyInt myInt1 = 10; std::cout << "myInt1: " << myInt1.getValue() << std::endl; MyInt myInt2 = 3.14; std::cout << "myInt2: " << myInt2.getValue() << std::endl; return 0; } ``` 在上面的示例中,我们定义了一个名为`MyInt`的类,它有两个构造函数。第一个构造函数接受一个`int`类型的参数,用于初始化`m_value`成员变量。第二个构造函数接受一个`double`类型的参数,通过使用`static_cast`将其转换为`int`类型,并将结果赋值给`m_value`成员变量。 在`main`函数中,我们分别使用`10`和`3.14`初始化了两个`MyInt`对象。由于存在类型转换构造函数,编译器会自动将`10`转换为`int`类型,并调用第一个构造函数进行对象的初始化。同样地,编译器会将`3.14`转换为`double`类型,并调用第二个构造函数进行对象的初始化。 输出结果为: ``` myInt1: 10 myInt2: 3 ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值