zoukankan      html  css  js  c++  java
  • C++基础:C++中的explicit关键字

        C++中,explicit用来修饰类的构造函数,表明该构造函数是显式的,不能发生隐式类型转换(implicit type conversion)。所有的单参数的构造函数都应该是explicit ,从而避免后台发生的隐式的类型转换。否则,在某些宽松的规则下,会发生没有进行显示类型转换操作而产生类型转换的情况。通常,这种情况会破坏代码的可读性,并导致难以发现的错误。

        那么何为隐式类型转换(implicit type conversion)?通常单参数构造函数定义了一个隐式类型转换,可以在编译的时候进行一个缺省的转换操作:将该构造函数对应数据类型的数据转换为该类对象的一个临时对象,从而使赋值等操作变成兼容的,如下面例子:

    class MyClass
    {
      public:
         MyClass(int num = 0):myValue(num){}
         int read() const
           {return myValue;}
         int write(int x)
            {myValue = x;}
      private:
         int myValue;
    }
    ...
    MyClass myclass;
    myclass = 10;//this will convert int to MyClass

                以上代码定义了一个MyClass的对象myclass,并对其赋值。编译器会自动将整型转换为MyClass类对象,实际上等同于下面的操作:

    MyClass temp(10);
    MyClass myclass = temp;

            以上操作即是所谓的隐式类型转换。
            如果要避免这种自动转换的,就需要用到关键字explicit,将类的构造函数声明为"显示"。在声明构造函数的时候,前面添加上explicit关键字,这样就可以防止这种自动的转换操作,代码如下所示

    class MyClass
    {
      public:
         explict MyClass(int num = 0):myValue(num){}
         int read() const
           {return myValue;}
         int write(int x)
            {myValue = x;}
      private:
         int myValue;
    }

             这样,在进行赋值操作的时候,由于已经使用explicit,意味着单参数的构造函数不能进行隐式的类型转换,编译器就可以正确的分析出这是一个类型不匹配的问题。

  • 相关阅读:
    高可用开源方案 Keepalived VS Heartbeat对比
    linux服务器之LVS、Nginx和HAProxy负载均衡器对比总结
    lvs + keepalived + httpd 高可用集群(转)
    OSPF 原理
    网络层 IP 协议首部格式与其配套使用的四个协议(ARP,RARP,ICMP,IGMP)
    WiresShark 一站式学习
    WiresShark 使用方法
    缺陷管理工具JIRA破解版及其安装方法
    Android开发之旅:环境搭建及HelloWorld
    五款超实用的开源 SVG 工具
  • 原文地址:https://www.cnblogs.com/f8master/p/3826085.html
Copyright © 2011-2022 走看看