zoukankan      html  css  js  c++  java
  • effective c++(04)之对象使用前初始化

    对于内置类型以外的初始化责任落在构造函数身上。如下:

    class PhoneNumber{};
    class ABEntry{
    public:
        ABEntry( const string& name, const string& address, const list<PhoneNumber>& phones );
    private:
        string theName;
        string theAddress;
        list<PhoneNumber> thePhones;
        int numTimesConsulted;
    };
    
    ABEntry::ABEntry( const string& name, const string& address, const list<PhoneNumber>& phones )
    {
        theName = name;
        theAddress = address;
        thePhones = phones;
        numTimesConsulted = 0;
    }

    以上对数据成员不是初始化,而是赋值。初始化发生在更早的时候,发生于这些成员的default构造函数被自动调用之时。

    ABEntry::ABEntry( const string& name, const string& address, const list<PhoneNumber>& phones )
    :  theName(name),
    theAddress(address), thePhones(phones), numTimesConsulted(
    0)
    {}

    以上这个通常效率要高,这次只调用了一次默认构造函数而没有使用赋值。

    规则:总是在初值列中列出所有的成员变量,以免还要记住那些成员变量可以无需初值。

    如果成员变量是const或者references,他们就一定需要初值而不能被赋值。最简单做法:总是使用成员初值列。

    成员初始化次序:base classes更早于derived classes被初始化。class成员总是以其声明的次序被初始化(即privated中的次序)。

    class FileSystem{
    public:
        size_t numDisks() const;
    };
    extern FileSystem tfs;
    
    class Directory{
        Directory( params);
    };
    Directory::Directory(params)
    {
        size_t disks = tfs.numDisks();
    }
    Directory tempDir(params);

    以上FileSystem和Directory属于不同的文件系统,tempDir在使用之前需要将tfs初始化。但是系统并不能保证其初始化,如何将tfs这个non-local static对象在被disks使用前进行初始化。方法:将每个non-local static对象搬到自己的专属的函数里面,返回一个reference指向所包含的对象。使得non-local static对象被local static对象所替代。解决方案如下:

    总结

    1. 为内置类型对象进行手工初始化,因为c++不一定保证初始化他们;

    2. 构造函数最好使用成员初值列,而不要在构造函数本体内使用赋值操作。初值列列出的成员变量,排列次序应该和声明次序相同;

    3. 为免除“跨编译单元制初始化次序”问题,以local static对象替换non-local static对象。

  • 相关阅读:
    turtle绘制彩色螺旋线
    turtle 画一朵花
    Spark Streaming+Kafka提交offset实现有且仅有一次(exactly-once)
    利用Spark实现Oracle到Hive的历史数据同步
    spark-submit提交Spark Streamming+Kafka程序
    SparkStreaming+Kafka 实现统计基于缓存的实时uv
    SparkStreaming+Kafka 实现基于缓存的实时wordcount
    基于OGG的Oracle与Hadoop集群准实时同步介绍
    Spark Streaming连接Kafka入门教程
    spark连接hive(spark-shell和eclipse两种方式)
  • 原文地址:https://www.cnblogs.com/2011winseu/p/3181853.html
Copyright © 2011-2022 走看看