【Effective c++】条款6:若不想使用编译器自动生成的函数就应该明确拒绝

【Effective c++】条款6:若不想使用编译器自动生成的函数就应该明确拒绝

地产中介卖的是房子,其使用的中介软件系统应该有个类用来描述卖掉的房子

class HomeFoeSale { ......}

但是任何房子都是独一无二的,不应该存在两个房子拥有同样的属性,因此以下操作不应该正确!

HomeForSale h;

HomeForSale h1(h);      //调用复制构造函数

HomeForSale h2 = h;     //调用赋值操作符

阻止这两个操作(复制、赋值)可以不声明它们,but自己不声明,编译器会自动生成,并且访问权限还是public。没办法只好声明出来,但是如何组织这两个操作呢,好吧,把他们的访问权限声明为private,因为阻止这两个操作,因此只声明,不定义。例如:

#include <iostream>

#include <vector>

using namespace std;



class base 

{

    public:

        base() {};

    private:

        base(const base&);

        base& operator=(const base&);

};





int main()

{

    base b;

    base b1(b);

}

结果

del5.cc: 在函数‘int main()’中:

del5.cc:10:3: 错误: ‘base::base(const base&)’是私有的

del5.cc:18:11: 错误: 在此上下文中

 

但是问题又来了:如果类中的成员函数或类的友元函数访问咋整,例如:

#include <iostream>

#include <vector>

using namespace std;



class base 

{

    public:

        base() {};

        void hello() { base b; base m(b); base n = b; } 

    private:

        base(const base&);

        base& operator=(const base&);

};





int main()

{

    base b;

}

可以利用继承来解决例如

#include <iostream>

#include <vector>

using namespace std;



class base 

{

    protected:

        base() {};

        ~base() {};

    private:

        base(const base&);

        base& operator=(const base&);

};



class HomeForSale : public base

{

    public:

        HomeForSale() : base() {}

};



int main()

{

    HomeForSale d;

}

这样,HoemForSale的朋友或成员函数也无力回天了(毕竟父类的函数是private的).

 

反思

c++ 中的流对象就是采用这样的原理.

#include <iostream>

#include <fstream>

#include <vector>

using namespace std;





int main()

{

    ifstream i;

    ifstream i2(i);

}

错误提示

/usr/include/c++/4.6/bits/ios_base.h:788:5: 错误: ‘std::ios_base::ios_base(const std::ios_base&)’是私有的

 

 

 

你可能感兴趣的:(effective)