Chinaunix首页 | 论坛 | 博客
  • 博客访问: 17696
  • 博文数量: 34
  • 博客积分: 990
  • 博客等级: 准尉
  • 技术积分: 330
  • 用 户 组: 普通用户
  • 注册时间: 2010-07-31 20:57
文章分类
文章存档

2012年(8)

2011年(26)

我的朋友
最近访客

分类: C/C++

2011-11-02 08:11:34

  1. class A{
  2.      int a;
  3.      public:
  4.      explicit A(int i):a(i){}
  5. };

  6. int main()
  7. {
  8.      A a(1),b(2);
  9.      a = b;
  10.      a = 2; //错误,不能隐式转换
  11.      return 0;
  12. }
另外:上面的转换仅限于单参数的构造函数而言,多参数的构造类是不涉及这个问题的。即:a(1,2);是不会有隐形转化的问题的。
  1. A b(1);
  2. A a = b; //这样才调用拷贝构造函数
  3. A c = 2; //调用带int参数(有且仅有一个非缺省参数)的构造函数。

  4. 如果是这样:
  5. A a(1),b(2),c(3);
  6. a = b; //调用operator=()
  7. a = 2; //调用operator=(),因为缺省的operator=的参数类型是(const &),所以这里有一个
  8.        //隐式转换,构造出一个临时对象A(2),就从2转换到了A(2)
  9.        //operator=函数里处理的就是临时 对象A(2)
  10.        //假如重载了operator=(int a),那就简单了。

阅读(183) | 评论(0) | 转发(0) |
0

上一篇:big endian和little endian

下一篇:DragAcceptFiles

给主人留下些什么吧!~~