按照默认规定,只有一个参数的构造函数也定义了一个隐式转换,将该构造函数对应数据类型的数据转换为该类对象,如下面所示:
class String {
String ( const char* p ); // 用C风格的字符串p作为初始化值
//…
}
String s1 = “hello”; //OK 隐式转换,等价于String s1 = String(“hello”);
但是有的时候可能会不需要这种隐式转换,如下:
class String {
String ( int n ); //本意是预先分配n个字节给字符串
String ( const char* p ); // 用C风格的字符串p作为初始化值
//…
}
下面两种写法比较正常:
String s2 ( 10 ); //OK 分配10个字节的空字符串
String s3 = String ( 10 ); //OK 分配10个字节的空字符串
下面两种写法就比较疑惑了:
String s4 = 10; //编译通过,也是分配10个字节的空字符串
String s5 = ‘a’; //编译通过,分配int(‘a’)个字节的空字符串
s4 和s5 分别把一个int型和char型,隐式转换成了分配若干字节的空字符串,容易令人误解。
为了避免这种错误的发生,我们可以声明显示的转换,使用explicit 关键字:
class String {
explicit String ( int n ); //本意是预先分配n个字节给字符串
String ( const char* p ); // 用C风格的字符串p作为初始化值
//…
}
加上explicit,就抑制了String ( int n )的隐式转换,
下面两种写法仍然正确:
String s2 ( 10 ); //OK 分配10个字节的空字符串
String s3 = String ( 10 ); //OK 分配10个字节的空字符串
下面两种写法就不允许了:
String s4 = 10; //编译不通过,不允许隐式的转换
String s5 = ‘a’; //编译不通过,不允许隐式的转换
因此,某些时候,explicit 可以有效得防止构造函数的隐式转换带来的错误或者误解
----------------------------------------------------------
explicit 只对构造函数起作用,用来抑制隐式转换。如:
class A {
A(int a);
};
int Function(A a);
当调用 Function(2) 的时候,2 会隐式转换为 A 类型。这种情况常常不是程序员想要的结果,所以,要避免之,就可以这样写:
class A {
explicit A(int a);
};
int Function(A a);
这样,当调用 Function(2) 的时候,编译器会给出错误信息(除非 Function 有个以 int 为参数的重载形式),这就避免了在程序员毫不知情的情况下出现错误。
总结:explicit 只对构造函数起作用,用来抑制隐式转换。
分享到:
相关推荐
在C++编程语言中,`explicit`关键字是一个非常重要的特性,它用于控制类的构造函数如何进行隐式类型转换。本文将深入探讨`explicit`构造函数的概念、作用以及如何避免潜在的编程错误。 首先,让我们理解什么是构造...
在C++编程中,"没有可用的复制构造函数或复制构造函数声明"是一个常见的错误,通常出现在尝试复制一个对象,而该对象的类没有定义复制构造函数时。在这个特定的情境中,问题出在一个名为`CArray, int>`的自定义数组...
按照默认规定,只有一个参数的构造函数也定义了一个隐式转换,将该构造函数对应数据类型的数据转换为该类对象,如下面所示: class String { String ( const char* p ); // 用C风格的字符串p作为初始化值 /...
1. 无参数构造函数:这是编译系统默认提供的一种构造函数,如果类中没有定义任何构造函数,系统会自动生成一个无参构造函数,通常用于执行默认的初始化操作。一旦我们定义了自己的构造函数,系统就不会再提供默认的...
C++中的拷贝构造函数和关键字explicit详解 C++中的拷贝构造函数是一种特殊的构造函数,它用于初始化对象时拷贝另一个对象的内容。拷贝构造函数的格式为`Type::Type(const Type&)`,其中`Type`是类的名称。拷贝构造...
显式构造函数通过使用`explicit`关键字来防止隐式类型转换,防止可能导致意外行为的自动类型转换。例如,如果`Box`有一个接受单个整数参数的构造函数,显式构造函数可以防止像`Box b = 42;`这样的隐式转换。 7. ...
C++中的类构造函数是类的一个特殊成员函数,它的主要任务是对类的对象进行初始化。构造函数的名字与类名相同,且没有返回类型。当我们声明一个类的对象时,编译器会自动调用相应的构造函数来分配内存并初始化对象的...
C++中的显式构造函数(Explicit Constructors)是编程实践中一个重要的概念,主要用来控制类对象的隐式类型转换。在C++中,如果一个类有一个只接受一个参数的构造函数,那么这个构造函数可以被用来进行隐式类型转换...
- 非C++内建类型之间的隐式转换通常涉及继承、转换操作符、非explicit构造函数和赋值操作符: - **a)** 当`B`公有继承自`A`时,`B`对象可以被隐式转换为`A`类型。 - **b)** 如果`B`类有一个`operator A()`,那么`...
非内建类型之间的隐式转换可以通过公有继承、转换操作符、非explicit构造函数或者赋值操作实现。 4. **默认构造函数的使用**: 使用默认构造函数初始化对象时,不需要括号。因此,`Test b();`会被解释为函数声明...
8. 非C++内建类型之间的隐式类型转换通常发生在继承、类型转换运算符、非explicit构造函数和赋值操作中。 9. 问题3的代码中,sizeof(str)/sizeof(str[0])计算的是字符数组的长度,不包括结束符'\0',所以输出的不是...
在C++编程语言中,`explicit`关键字是一个非常重要的特性,它主要用于控制构造函数的隐式类型转换。本文将深入探讨`explicit`的作用,并通过示例代码帮助理解其工作原理。 `explicit`关键字用于声明单参数构造函数...
23.6 explicit构造函数 23.7 成员初始化语法 23.8 利用关键字asm 23.9 连接说明 23.10 基于数组的I/O 23.11 C与C++的区别 第24章 标准模板库 24.1 STL概述 24.2 容器类 24.3 一般的操作原理 24.4 vector容器 24.5 ...
如果 `A` 类有一个非 explicit 构造函数,接受一个 `B` 类型的引用或指针作为参数,那么 `B` 对象可以被隐式地用于创建 `A` 对象。 d. 虽然不是严格意义上的类型转换,但赋值操作符 `operator=` 如果接受一个 `...
c) 类A有一个接受B类型的非explicit构造函数;d) 类A实现了赋值操作符,尽管这不是正式的类型转换,但也可以视为一种形式。 3. sizeof(str)/sizeof(str[0])用于计算字符串数组的元素个数,不包括结束符'\0',因此...
在C++编程语言中,`explicit`关键字是一个重要的特性,用于控制类的构造函数的隐式类型转换。这个关键字主要用于防止编译器自动执行单参数构造函数的隐式转换,从而减少潜在的错误和混淆。下面我们将深入探讨`...
为了防止这种情况,我们可以使用`explicit`关键字来禁止单参数构造函数的隐式类型转换。例如: ```cpp class MyClass { public: explicit MyClass(int value) : myValue(value) {} // 明确禁止隐式转换 private: ...
6. **explicit构造函数**: explicit关键字用于构造函数声明,防止隐式类型转换,避免程序员无意中创建了不必要的临时对象,提高代码的清晰性和安全性。 STL的使用极大地提高了C++程序员的生产力,它提供的工具...