[C++]转换函数

1.对于系统的预定义的基本数据类型,C++提供了两种类型转换方式:隐式类型转换和显示类型转换。

int a=5,sum;
double b=5.55;
sum=a+b;    //隐式类型转换:编译系统首先将a的值由int转换为double,然后与b相加得到10.55,在向整形变量sum赋值时,将10.55转换为整形数10,赋值给变量sum;
cout<<"隐式转换:a+b="<<sum<<endl;

//显示类型转换
sum=(int)(a+b);    //C语言的形式
sun=int(a+b);      //C++的形式
cout<<"显示转换:a+b="<<sum<<endl;

2.对于用户自定义的类类型实现与其它数据类型的转换,C++提供了以下两种方法:

(1) non-ecplicit-one-argument ctor    (转换构造函数)

(2) conversion function    (类型转换函数)

  以complex类为例,来讲述上面的两个函数:

//Complex类的定义

#include <iostream>
using namespace std;

class Complex
{
private:
	double real;
	double imag;
public:

	Complex(double real, double imag)
	{
		this->real = real;
		this->imag = imag;
	}
	
	Complex(double real=0)    //转换构造函数 non-explicit-one-argument ctor
	{
		real = real;
		imag = 0;
	}
	
	Complex operator+(Complex com1);
	void showComplex();
};

Complex Complex::operator+(Complex com1)
{
	return Complex(real + com1.real, imag + com1.imag);
}

void Complex::showComplex()
{
	cout << real;
	if (imag>0)
		cout << "+";
	if (imag != 0)
		cout << imag << "i" << endl;
}

int main()
{
	Complex com(10, 10), sum;
	sum = com + 5.5;    //5.5调用Complex(5.5)生成临时对象,然后再与com相加
	sum.showComplex();	//输出为 15.5+10i
	while (1);
	return 0;
}

  如果在转换构造函数前加上explicit关键字,则5.5不会隐式地转换为Complex类,必须 Complex(5.5), 代码如下所示

//Complex类的定义

#include <iostream>
using namespace std;

class Complex
{
private:
	double real;
	double imag;
public:

	Complex(double real, double imag)
	{
		this->real = real;
		this->imag = imag;
	}
	
	explicit Complex(double r=0.0)    //加上explicit关键字
	{
		real = r;
		imag = 0;
	}
	
	Complex operator+(Complex com1);
	void showComplex();
};

Complex Complex::operator+(Complex com1)
{
	return Complex(real + com1.real, imag + com1.imag);
}

void Complex::showComplex()
{
	cout << real;
	if (imag>0)
		cout << "+";
	if (imag != 0)
		cout << imag << "i" << endl;
}

int main()
{
	Complex com(10, 10), sum;
	sum = com + Complex(5.5);    //对应地,必须用Complex来显示地调用转换构造函数
	sum.showComplex();	//输出为 15.5+10i

	while (1);
	return 0;
}

  从上面可以看出,转换构造函数的形式如下:

 类名(待转换类型)

  {

    函数体;

  }

 转换构造函数不仅能将预定义的数据类型转换为自定义类型的对象,也可以将另一个类的对象转换为转换构造函数所在类的对象。但转换构造函数不能把累的对象转换成基本数据类型,比如不能讲Complex类的对象转换成double类型数据,于是C++中引入了类型转换函数来解决这个问题。类型转换函数的一般形式如下:

    operator 目标类型()

    {

         ...

         return 目标类型的数据;

    }

  目标类型是索要转换的类型名,既可以是预定义及基本类型,也可以说是自定义类型,需要注意的是:

a.类型转换函数的函数名(operator 目标类型) 前不能指定返回类型

b. 没有参数

c.在函数体最后一条语句一般为return语句,返回的是目标类型的数据

  下面看下相关的例子:

#include <iostream>  

class Complex //复数类  
{
private://私有  
	double real;//实数  
	double imag;//虚数  
public:
	Complex(double real, double imag)
	{
		this->real = real;
		this->imag = imag;
	}
	Complex(double d = 0.0)//转换构造函数  
	{
		real = d;//实数取double类型的值  
		imag = 0;//虚数取0  
	}
	Complex operator+(Complex com1);//或friend Complex operator+(Complex com1,Complex com2);  
	void showComplex();
	operator double();
};

Complex Complex::operator+(Complex com1)
{
	return Complex(real + com1.real, imag + com1.imag);
}

void Complex::showComplex()
{
	std::cout << real;
	if (imag>0)
		std::cout << "+";
	if (imag != 0)
		std::cout << imag << "i" << std::endl;
}

Complex::operator double()
{
	return real;
}

int main()
{
	Complex com(10, 10);
	double total1, total2;
	total1 = double(com) + 5.5;//double(com)把复数(10+10i)转换为双精度数10.0  
	total2 = 5.5 + com; // 写成 total2 = com + 5.5 是错误的   
	std::cout << "把Complex类显式对象转化为double类型与5.5相加为:" << total1 << std::endl;
	std::cout << "把Complex类对象隐式转化为double类型与5.5相加为:" << total2 << std::endl;
	while (1);
	return 0;
}

  注意要说明的是total2=com+5.5;会报错,原因是会出现歧义,是com用转换函数转换为double型,进行double定义的加法,还是5.5利用转换构造函数转换为Complex的临时变量,进行Complex定义的加法。

注:参考博客 https://www.cnblogs.com/forcheryl/p/3955407.html

 

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值