• c++ explicit


    C++中, 一个参数的构造函数(或者除了第一个参数外其余参数都有默认值的多参构造函数), 承担了两个角色。 1 是个构造器 ,2 是个默认且隐含的类型转换操作符。
    所以, 有时候在我们写下如 AAA = XXX, 这样的代码, 且恰好XXX的类型正好是AAA单参数构造器的参数类型, 这时候编译器就自动调用这个构造器, 创建一个AAA的对象。
    这样看起来好象很酷, 很方便。 但在某些情况下(见下面权威的例子), 却违背了我们(程序员)的本意。 这时候就要在这个构造器前面加上explicit修饰, 指定这个构造器只能被明确的调用,使用, 不能作为类型转换操作符被隐含的使用。 呵呵, 看来还是光明正大些比较好。
    explicit构造函数的作用
    解析:
    explicit构造函数是用来防止隐式转换的。请看下面的代码:
    class Test1
    {
    public:
        Test1(int n) { num = n; } //普通构造函数
    private:
        int num;
    };
    class Test2
    {
    public:
        explicit Test2(int n) { num = n; } //explicit(显式)构造函数
    private:
        int num;
    };
    int main()
    {
        Test1 t1 = 12; //隐式调用其构造函数, 成功,把整形赋给类类型,猛一感觉很奇怪,其实隐式调用了构造函数
        Test2 t2 = 12; //编译错误,不能隐式调用其构造函数
        Test2 t3(12); //显式调用成功,显示调用其构造函数Test2(int)
        return 0;
    }
    Test1的构造函数带一个int型的参数,代码17行会隐式转换成调用Test1的这个构造函数。而Test2的构造函数被声明为explicit(显式),这表示不能通过隐式转换来调用这个构造函数,因此代码18行会出现编译错误。
    普通构造函数能够被隐式调用。而explicit构造函数只能被显示调用。
  • 相关阅读:
    浅析堆与垃圾回收
    再探JVM内存模型
    索引使用的基本原则
    常见的索引模型浅析
    初识InnoDB体系架构和逻辑存储结构
    一条update SQL语句是如何执行的
    MySQL一条查询语句是如何执行的
    堆与优先队列
    ibatis BindingException Parameter 'status' not found. Available parameters are [arg1, arg0, param1, param2] 解决方法
    Mysql通过MHA实现高可用
  • 原文地址:https://www.cnblogs.com/zzyoucan/p/3672150.html
Copyright © 2020-2023  润新知