C++ explicit关键字讲解

目录
  • 1 隐式转换
  • 2 显示转换

前言:

C++编码时,可以通过构造函数将相应的数据类型转换成为C++类的对象,从某种程度来说给编码带来了方便,但并不是每次都正确,为了避免这种情况,C++提供了explicit关键字,相对于implicit而言,他默认关闭了隐式类型转换方法。至于两者有什么区别,通过下面的代码进行比较说明。

1 隐式转换

C++ 构造函数默认类型为implicit,定义时既可以显示说明也可以默认不加该标识符。

// 没有使用explicit关键字的类声明, 即默认为隐式声明
class CString{
private:
    char *m_pStr;
    int m_iSize;
public:
    CxString(int size){
        m_iSize = size;
        m_pStr = malloc(m_iSize + 1);
        memset(m_pStr, 0, m_iSize + 1);
    }
    CxString(const char *p)  {
        int size = strlen(p);
        m_pStr = malloc(size + 1);
        strcpy(m_pStr, p);
        m_iSize = strlen(m_pStr);
    }
    ~ CxString(){
        if(m_pStr)
        {
            delete m_pStr;
            m_pStr = nullptr;
        }
    }
};

如上的代码中在实例化类的对象时以下方法都是正确的。

如下所示:

CString str1("12121");//CxString(const char *p)
CString str2="abc";//CxString(const char *p)
CString str4(4);//CxString(int size)
CString str5=6;//CxString(int size)

上面的使用方式都会默认调用相应的构造函数实现对象的初始化,以CString str5=6为例,在对对象进行实例化的过程中主要进行了如下操作:

CString string5(6);
//或者如下所示
CString temp(6);
CString string5 = temp;

2 显示转换

在构造函数上使用了explicit关键字后,通过构造函数进行对象实例化时需要进行显示类型转化。否则将会报错。

依旧以上面的代码为例:

class CString{
private:
    char *m_pStr;
    int m_iSize;
public:
    explicit CString(int size) {
        m_iSize = size;
        m_pStr = (char *)malloc(m_iSize + 1);
        memset(m_pStr, 0, m_iSize + 1);
    }
    explicit CString(const char *p){
        int size = strlen(p);
        m_pStr = (char *)malloc(size + 1);
        strcpy(m_pStr, p);
        m_iSize = strlen(m_pStr);
    }
};

如上:再次使用相同得到方式对类进行实例化时将会报错,报错内容如下:

通过运行结果可以说明:explicit关键字可以防止构造函数进行隐式自动转换

3 再次拆解

explicit关键字只对构造函数有一个参数的形式有效,如果构造函数有多个参数时explicit的功能也将失效,但是C++也提供了一种例外,既如果构造函数的其他参数都有默认值及时参数个数大于1个explicit也是生效的。

如下面的代码所示:

class CPoint
{
private:
    float m_fX;
    float m_fY;
public:
    explicit CPoint(float x,float y=9.8):m_fX(x),m_fY(y)
    {  

    }
};
int main()
{
    CPoint point1(2,3);
    CPoint point2=4.5;
    return 0;
}

如代码所示,编译时将会报错,报错内容为:

如果要解决上面的问题可以用下面得到方法:

按照显示类型转换的方式进行处理,如:

 CPoint point1(2,3);
CPoint point2(4.5);

将explicit关键字去掉,允许构造函数进行隐式转换数据类型,如:

CPoint(float x,float y=9.8):m_fX(x),m_fY(y)
{
}

到此这篇关于C++ explicit关键字讲解的文章就介绍到这了,更多相关C++ explicit关键字内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • C++ explicit关键字的应用方法详细讲解

    C++编程语言中有很多比较重要的关键字在实际编程中起着非常重要的作用.我们今天为大家介绍的C++ explicit关键字就是其中一个应用比较频繁的关键字.下面就让我们一起来看看这方面的知识吧. C++ explicit关键字用来修饰类的构造函数,表明该构造函数是显式的,既然有"显式"那么必然就有"隐式",那么什么是显示而什么又是隐式的呢? 如果c++类的构造函数有一个参数,那么在编译的时候就会有一个缺省的转换操作:将该构造函数对应数据类型的数据转换为该类对象,如下面

  • C++ explicit关键字的使用详解

    在C++中,我们有时可以将构造函数用作自动类型转换函数.但这种自动特性并非总是合乎要求的,有时会导致意外的类型转换,因此,C++新增了关键字explicit,用于关闭这种自动特性.即被explicit关键字修饰的类构造函数,不能进行自动地隐式类型转换,只能显式地进行类型转换. 注意:只有一个参数的构造函数,或者构造函数有n个参数,但有n-1个参数提供了默认值,这样的情况才能进行类型转换. 下面通过一段代码演示具体应用(无explicit情形): /* 示例代码1 */ class Demo {

  • c/c++拷贝构造函数和关键字explicit详解

    关键字explicit 修饰构造方法的关键字,加上了,就告诉编译器,不可以隐式初始化对象:不加就可以隐式初始化对象: 下面的代码是可以正常编译执行的,但是加了关键字explicit,编译就会错我,因为Test t = 100;是隐式初始化对象,但是如果加上强制类型转换后,就不会有错误了. 强制类型转换:Test t = (Test)100; class Test{ public: Test(int d):data(d){//explicit cout << "C:" <

  • c++中explicit与mutable关键字的深入探究

    今天说一说c++里面的两个关键字explicit和mutable. 1. explicit关键字 在写c++标准输入输出相关文章,查看iostream实现代码的时候,经常看到构造函数前面带有explicit关键字,那么它到底有什么作用呢. explicit用来防止由构造函数定义的隐式转换,先看这样一段代码: #include <iostream> class Base { private: int a; public: Base(int p_a){ a = p_a;} ~Base(){} vo

  • C++ Explicit关键字详细解析

    explicit关键字用来修饰类的构造函数,表明构造函数是显示的,相对的是implicit关键字.首先这个关键字只能用在类内部的构造函数声明上,而不能用在类外部的函数定义上,它的作用是不能进行隐式转换. 复制代码 代码如下: class gxgExplicit  //没有关键字explicit的类    {      public:          int _size;         gxgExplicit(int size)        {           _size = size;

  • C++中的explicit关键字实例浅析

    在C++程序中很少有人去使用explicit关键字,不可否认,在平时的实践中确实很少能用的上.再说C++的功能强大,往往一个问题可以利用好几种C++特性去解决.但稍微留心一下就会发现现有的MFC库或者C++标准库中的相关类声明中explicit出现的频率是很高的.了解explicit关键字的功能及其使用对于我们阅读使用库是很有帮助的,而且在编写自己的代码时也可以尝试使用.既然C++语言提供这种特性,我想在有些时候这种特性将会非常有用. 按默认规定,只用传一个参数的构造函数也定义了一个隐式转换.举

  • C++ explicit关键字讲解

    目录 1 隐式转换 2 显示转换 前言: C++编码时,可以通过构造函数将相应的数据类型转换成为C++类的对象,从某种程度来说给编码带来了方便,但并不是每次都正确,为了避免这种情况,C++提供了explicit关键字,相对于implicit而言,他默认关闭了隐式类型转换方法.至于两者有什么区别,通过下面的代码进行比较说明. 1 隐式转换 C++ 构造函数默认类型为implicit,定义时既可以显示说明也可以默认不加该标识符. // 没有使用explicit关键字的类声明, 即默认为隐式声明 cl

  • C++中的explicit关键字详解

    目录 前言 1. 抑制构造函数定义的隐式转换 2. 为转换显式地使用构造函数 3. 类型转换运算符可能产生意外结果 4. 显示的类型转换运算符 5. explicit练习 5.1 当不使用explict关键字时 5.2 使用explict关键字时 5.3 explicit 标识的构造函数中存在一个默认值 前言 最近在阅读android底层源码的时候,发现其中好多代码使用了explicit关键字,因此这里对explicit关键字进行了分析和介绍. 1. 抑制构造函数定义的隐式转换 在要求隐式转换的

  • Java中的Native关键字讲解

    目录 一.Java中Native关键字的语法 二.Native关键字是如何工作的? 三.代码示例 四.Java中Native关键字的优势 五.规则 六.总结 前言: native关键字充当JAVA语言与除JAVA之外的其他语言编写的代码块或库之间的链接,这可能取决于您操作的机器.如果将native关键字应用于一个方法,那么这意味着该方法将通过JNI(JAVA native interface)使用其他语言(如C或C++)编写的本机代码来实现. 一.Java中Native关键字的语法 本机代码的语

  • C++图文并茂讲解类型转换函数

    目录 一.类型转换函数(上) 1.再论类型转换 2.问题 3.再论构造函数 4.另一个视角 5.编译器的行为 6.小结(上) 二.类型转换函数(下) 1.类型转换 2.编译器的行为 3.注意事项 4.小结(下) 一.类型转换函数(上) 1.再论类型转换 标准数据类型之间会进行隐式的类型安全转换 转换规则如下: 下面来看一个有趣的隐式类型转换: #include <iostream> #include <string> using namespace std; int main()

  • 浅谈C++ Explicit Constructors(显式构造函数)

    C++ 为类(Class)提供了许多默认函数.如果自己没有申明,编译器会为我们提供一个copy构造函数.一个copy assignment操作符和一个析构函数.此外,如果没有申明任何构造函数,编译器会为我们申明一个default构造函数.很像下面的Empty类: class Empty{ public: Empty(); Empty(const Empty &rhs); ~Empty(); Empty& operator=(const Empty &rhs); }; 就像Effec

随机推荐