版权声明
---------------------------------------------------------------------------------------------------------------------
该文章原创于Qter开源社区(www.qter.org)
作者: 女儿叫老白 (白振勇)
转载请注明出处!
---------------------------------------------------------------------------------------------------------------------
课程目录:《C++老鸟日记》目录
本套课程属于:《C++跨平台开发干货》系列课程。
----------------------------------------------------------------------------------------------------------------------
引言:
----------------------------------------------------------------------------
今天从网上看到一个视频,讲的是a与b属于不同的类型,给出让a=b等式成立的一种方法,我联想起几年前看到的一则面试题,也是这个题目。我们来看一下都有哪些办法能让A=B成立。
正文:
----------------------------------------------------------------------------
不卖关子了,直接给答案。
方法1,这个方法不太通用,说的是基本数据类型,比如a是float,b是int。
编译器会自动做隐式类型转换。我们不做过多讨论。
方法2,class B从classA派生。
// class.h
class A {
};
class B : public class A {
};
A a;
B b;
a = b; // ok
这里利用的是A、B的派生关系。父类对象可以指向子类。
方法3,class A重载operator=操作符。
// class.h
class B{
};
class A {
public:
A& operator= (const B&);
};
这里利用的是重载赋值操作符(operator=),用的是隐式。
方法4,class A提供拷贝构造函数A(const B&):
// class.h
class B{
};
class A {
public:
A(const B&);
};
这里利用的是A的拷贝构造函数,是隐式转换。插个题外话,如果不希望a=b成立,那么可以把拷贝构造函数前面加上explicit限定符,写成这样:
explicit A(const B&);
这样,编译器就会强制要求使用显示拷贝构造,啥意思呢?就是要写成这样:
a = A(b);
请注意,这里可不是强制类型转换哦,是调用A的拷贝构造函数。
方法5,class B重载operator A()接口:
// class.h
class A {
};
class B {
public:
operator A() const; // 相当于B提供一个接口,可以把自己转换成A。
};
B::operator A() const {
A a;
// 省略了为a赋值的代码。
return a;
}
结语:
----------------------------------------------------------------------------
仔细想想,这个问题还真是有不少办法可以解决。所以,当我们碰到难题的时候,一定要充分发掘一下自己的大脑,动用自己的全部C++知识来应对。呵呵,说的有点过了。希望本节能够为大家开阔一下解决问题的思路。