explicit -防止构造函数参数的隐式转换

class String {
String ( const char* p ); 
}
 
定义一个类。String s1 = “hello”; //OK 隐式转换,等价于String s1 = String(“hello”);
 
如果不需要隐式转换,如下:
class String {
        String ( int n );              //本意是预先分配n个字节给字符串
       String ( const char* p );        // 用C风格的字符串p作为初始化值
       //…
}
 
下面两种写法就比较疑惑了
String s4 = 10;      //编译通过,也是分配10个字节的空字符串
String s5 = ‘a’;     //编译通过,分配int(‘a’)个字节的空字符串,本来应该调用String ( const char* p )进行初始化的,结果却分   配了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 可以有效得防止构造函数的隐式转换带来的错误或者误解。
 
 
 
 
 
 
原文:https://blog.csdn.net/ygm_linux/article/details/25369073
posted @ 2020-03-02 14:23  撑雨伞的小男孩  阅读(303)  评论(0编辑  收藏  举报