【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&)’是私有的
上一篇:javaweb 在netbeans 上的部署问题


下一篇:java 枚举类型