C++隐式类型转换操作符
2013-11-26 22:47
986 查看
前几天看MFC时碰到了一个让我困惑不已的问题:
CDC::Rectangle的某一个原型如下:
其中LPCRECT是const RECT*
但是诸如如下所示的调用也能通过编译:
其中CRect是RECT的派生类。
这样岂不是把一个对象传入了需要指针作为参数的函数?
补充:CDC::Rectangle没有需要传入对象的重载版本。
问题的链接在这里:http://www.dewen.org/q/15557
直到不久前我才发现的端倪:
CRect实现了LPCRECT()运算符,这是什么意思呢?原来这个叫做隐式类型转换操作符,在这里相当于支持CRect向LPCRECT的隐式转换。
这种语法可以产生一些好玩的语法糖:
不过滥用隐式类型转换是有害的,会导致一些不确定的行为(详见More effective C++条款5——对定制的“类型转换函数”保持警觉)。
CDC::Rectangle的某一个原型如下:
BOOL Rectangle(LPCRECT lpRect);
其中LPCRECT是const RECT*
但是诸如如下所示的调用也能通过编译:
myDC.Rectangle(CRect(p1, p2));
其中CRect是RECT的派生类。
这样岂不是把一个对象传入了需要指针作为参数的函数?
补充:CDC::Rectangle没有需要传入对象的重载版本。
问题的链接在这里:http://www.dewen.org/q/15557
直到不久前我才发现的端倪:
ATLTYPES_INLINE CRect::operator LPCRECT() const throw() { return this; }
CRect实现了LPCRECT()运算符,这是什么意思呢?原来这个叫做隐式类型转换操作符,在这里相当于支持CRect向LPCRECT的隐式转换。
这种语法可以产生一些好玩的语法糖:
#include <iostream> using namespace std; class A { public: A() {}; ~A() {}; operator A*() throw() { return this; } void Show() { cout << "I'm Uranux!" << endl; } }; int main() { A* pA = A(); // 若没有实现operator A*,则只能A* pA = new A(); pA->Show(); return 0; }
不过滥用隐式类型转换是有害的,会导致一些不确定的行为(详见More effective C++条款5——对定制的“类型转换函数”保持警觉)。
相关文章推荐
- [C++再学习系列] 隐式类型转换与转换操作符operator T
- C++ 隐式类类型转换和转换操作符
- [C++再学习系列] 隐式类型转换与转换操作符
- [C++再学习系列] 隐式类型转换与转换操作符operator T
- [C++]复制构造函数、赋值操作符与隐式类类型转换
- [C++再学习系列] 隐式类型转换与转换操作符operator T
- 隐式类型转换 与 隐式类型转换操作符
- 【c++】explicit 隐式类类型转换
- C++ 中operator用法:隐式类型转换
- C++的四种cast操作符的区别--类型转换
- C++中显式和隐式初始化和类型转换
- C++类型转换操作符(type conversion operator)
- 对C++中类型显示转换操作符const_cast<类型>(变量)的认识
- C++类型转换分为:隐式类型转换和显式类型转换
- 细说C++类型转换操作符
- C++ 隐式类型转换
- 从Qt谈到C++(一):关键字explicit与隐式类型转换
- C++ 类型隐式转换学习
- C++ 隐式类类型转换