【C++基础之十七】抑制由构造函数定义的隐式转换
2013-11-28 15:38
399 查看
[b]原创作品,转载请标明:[/b]http://blog.csdn.net/jackystudio/article/details/17006543
有时候构造函数的隐式转换可以帮我们不少忙,但有时候它也会帮倒忙。所以我们应该要控制它,而不是让它无脑操作。
代码定义了类A,包含一个int型成员变量var,构造函数需要传入var的初始值,isSame函数用于判断2个类A的对象是否相等(通过判断成员变量var值)。上述代码获得结果是a==b。如果A b(3),获得的结果就是a!=b。
有时候构造函数的隐式转换可以帮我们不少忙,但有时候它也会帮倒忙。所以我们应该要控制它,而不是让它无脑操作。
1.示例
先看一段代码。#include "stdafx.h" using namespace std; class A { public: A(int v):var(v){};//带一个int型值的构造函数 bool isSame(const A& ref) const {return var==ref.var;}//判等函数 private: int var;//成员变量var }; int _tmain(int argc, _TCHAR* argv[]) { A a(5);//构造a对象 A b(5);//构造b对象 if (a.isSame(b)) cout<<"a==b"<<endl; else cout<<"a!=b"<<endl; }
代码定义了类A,包含一个int型成员变量var,构造函数需要传入var的初始值,isSame函数用于判断2个类A的对象是否相等(通过判断成员变量var值)。上述代码获得结果是a==b。如果A b(3),获得的结果就是a!=b。
2.构造函数定义引起的隐式转换
由于构造函数需要传入一个int型初始值,因此可以认为这是一个隐式转换,把一个int型值转换为一个A类型的对象。所以如果修改main函数为如下代码。int _tmain(int argc, _TCHAR* argv[]) { A a(5);//构造a对象 if (a.isSame(5))//这里会因为构造函数的隐式转换,因而正确执行isSame cout<<"a==b"<<endl; else cout<<"a!=b"<<endl; }这看起来不错,好像还省了不少力气,但是这样的使用依赖于用户是否有相应的需求,有时候它将成为一个bug。所以更好的办法是抑制这种由构造函数引起的隐式转换。
3.抑制抑制由构造函数定义的隐式转换
在构造函数中引入explicit可以帮我们解决这个问题。class A { public: explicit A(int v):var(v){};//引入explicit关键字 bool isSame(const A& ref) const {return var==ref.var;} private: int var; }; int _tmain(int argc, _TCHAR* argv[]) { A a(5); if (a.isSame(5)) cout<<"a==b"<<endl; else cout<<"a!=b"<<endl; }看看结果:
error C2664: “A::isSame”: 不能将参数 1 从“int”转换为“const A &” 1> 原因如下: 无法从“int”转换为“const A” 1> class“A”的构造函数声明为“explicit”好了,这样一来构造函数就无法进行隐式转换,
4.为转换进行显式使用构造函数
这时候仍想进行转换的话,显式使用构造函数吧。int _tmain(int argc, _TCHAR* argv[]) { A a(5); if (a.isSame(A(5)))//显式使用构造函数 cout<<"a==b"<<endl; else cout<<"a!=b"<<endl; }
5.总结
除非有明显的理由想利用构造函数定义的隐式转换,否则设置explicit可以避免一些错误,当需要进行转换的时候,由用户显式地调用构造函数。当然C++的临时对象都是const,如果isSame函参不是const型,则隐式调用构造函数时生成的临时对象也无法传入。相关文章推荐
- c++:explicit 抑制构造函数隐式转换
- 读书笔记--抑制构造函数定义隐式转换
- C/C++日常学习总结(第十二篇)将构造函数声明为explicit(显式)的方式可以抑制隐式转换
- C++ 抑制构造函数定义的隐式转换
- explicit:C++规定,当定义了只有一个参数的构造函数时,同时也定义了一种隐式的类型转换
- C++中的explicit关键字 - 抑制隐式转换(转)
- c++防止构造函数隐式转换示例
- [c++基础] 四种类型转换和隐式类型转换
- C++中复制构造函数和隐式转换
- C++ 学习之构造函数:构造函数小结3 默认构造函数、隐式类型转换和复制构造函数
- 如何抑制构造函数的隐式转换?
- C++定义隐式转换函数,将类转换为内部的一个成员变量
- explicit 只对构造函数起作用,用来抑制隐式转换
- 【C++自我精讲】基础系列五 隐式转换和显示转换
- C++中的explicit关键字 抑制隐式转换构造
- c++构造函数隐式转换--转换构造函数
- C++拾趣——类构造函数的隐式转换
- 【小记备忘】之C/C++ 杂记,catch,调用构造函数,内存分配,隐式转换【2013.12.11】
- C++ 学习之构造函数:构造函数小结3 默认构造函数、隐式类型转换和复制构造函数
- c++基础--隐式类类型转换