zoukankan      html  css  js  c++  java
  • QT中的explicit关键字的作用

    c++提供了关键字explicit,可以阻止不应该允许的经过转换构造函数进行的隐式转换的发生。声明为explicit的构造函数不能在隐式转换中使用。

      C++中, 一个参数的构造函数(或者除了第一个参数外其余参数都有默认值的多参构造函数), 承担了两个角色。一是个构造器,二是个默认且隐含的类型转换操作符。

      所以,有时候在我们写下如 AAA = XXX, 这样的代码, 且恰好XXX的类型正好是AAA单参数构造器的参数类型, 这时候编译器就自动调用这个构造器, 创建一个AAA的对象。

    这样看起来好象很酷,很方便。 但在某些情况下,却违背了我们(程序员)的本意。 这时候就要在这个构造器前面加上explicit修饰, 指定这个构造器只能被明确的调用、使用,不能作为类型转换操作符被隐含的使用。  

      请看下面的代码:

      1 class Test1

      2 {

      3 public:

      4 Test1(int n) { num = n; } //普通构造函数

      5 private:

      6 int num;

      7 };

      8

      9 class Test2

      10 {

      11 public:

      12 explicit Test2(int n) { num = n; } //explicit(显式)构造函数

      13 private:

      14 int num;

      15 };

      16

      17 int main()

      18 {

      19 Test1 t1 = 12; //隐式调用其构造函数成功

      20 Test2 t2 = 12; //编译错误,不能隐式调用其构造函数

      21 Test2 t3(12); //显示调用成功

      22 return 0;

      23 }

      Test1的构造函数带一个int型的参数,代码19行会隐式转换成调用Test1的这个构造函数。而Test2的构造函数被声明为explicit(显式),这表示不能通过隐式转换来调用这个构造函数,因此代码20行会出现编译错误。普通构造函数能够被隐式调用。而explicit构造函数只能被显示调用。

     
  • 相关阅读:
    494 Target Sum 目标和
    493 Reverse Pairs 翻转对
    492 Construct the Rectangle 构建矩形
    491 Increasing Subsequences 递增子序列
    488 Zuma Game 祖玛游戏
    486 Predict the Winner 预测赢家
    485 Max Consecutive Ones 最大连续1的个数
    483 Smallest Good Base
    Django Form组件
    Django Auth组件
  • 原文地址:https://www.cnblogs.com/C-Plus-Plus/p/13916827.html
Copyright © 2011-2022 走看看