C++中禁止类被派生的方法
来源:互联网 发布:局域网和广播网络区别 编辑:程序博客网 时间:2024/05/18 01:37
在我的那篇“C++中虚析构函数的作用”中我说明了为什么作为基类的类的析构函数必须是虚函数,同时也指出:为了避免产生虚函数表,如果类不是基类的话,析构函数就不需要声明为虚函数。
但是,我们不能预料用户的行为,你不敢肯定用户是否会从你的类去派生自己的类。如果用户以一个基类指针去删除一个派生类的对象,就会发生派生类的析构函数不被调用的情况。这样做的危险性我想大家都知道。当然,你可以在类的说明文档中,甚至是在类的头文件中,说明你写的类不能作为基类。可是,谁又能保证,用户会仔细阅读这些说明呢?
所以,我们最好的方法就是禁止类的派生。如果用户从你的类去派生自己的类,那么在编译阶段他就会知道这样做是错的,从而避免可能发生在运行阶段的析构函数不被调用的危险。而禁止类派生的方法就是把构造函数声明为私有的。例如下面的类就不能被派生:
{
public:
~ClxNotBase();
private:
ClxNotBase();
ClxNotBase(const ClxNotBase& rhs);
};
如果用户从类ClxNotBase派生了一个类,那么在编译阶段他就会得到一个不能访问私有成员函数的错误信息。
当然,你肯定会说:如果把类的构造函数声明为私有的,那么我们就无法构造这个类的对象,那我要这个类还有什么用呢?
是的,你说的很对。不过,我们可以用很简单的方法来解决这个问题。下面是修改过的类ClxNotBase:
{
public:
~ClxNotBase();
static ClxNotBase * NewlxNotBase();
static ClxNotBase * NewlxNotBase(const ClxNotBase& rhs);
private:
ClxNotBase();
ClxNotBase(const ClxNotBase& rhs);
};
ClxNotBase * ClxNotBase::NewlxNotBase()
{
// 调用真正的构造函数
return new ClxNotBase();
}
ClxNotBase * ClxNotBase::NewlxNotBase(const ClxNotBase& rhs)
{
// 调用真正的拷贝构造函数
return new ClxNotBase(rhs);
}
用户在要使用类ClxNotBase的时候,就可以调用伪构造函数NewlxNotBase来生成对象。当然,每个伪构造函数都调用了new,这就意味着用户必须在使用完类ClxNotBase的对象后都必须调用delete。但是,释放不用的资源是每个C++程序员的基本素质,这个我们就不用强调了。而且,现在有了智能指针auto_ptr,可以自动删除所指的对象,如果用户知道用智能指针的话,那就更好了。下面是一个例子:
在这种情况下,就不用考虑delete对象的问题。在对象离开作用域的时候,智能指针会自动删除其所指的对象。
- C++中禁止类被派生的方法
- C++中禁止类被派生的方法
- C++中禁止类被派生的方法
- C++中禁止类被派生的方法
- C++中禁止类被派生的方法
- C++中禁止类被派生的方法
- C++中禁止类被派生的方法
- C#高级(五)继承,派生类,派生类的构造方法
- C#高级(五)继承,派生类,派生类的构造方法
- C++中禁止类被继承的方法
- C++中禁止类被继承的方法
- O-c中类的继承与派生的概念
- [c++]派生类的应用
- C++: 类的继承派生
- 派生类的构造方法
- c#基础-继承,派生类,派生类的构造 方法
- 派生类的派生类中(override)的表现
- 派生类中new方法和override重载方法的区别
- Jquery ajax
- InstallShield Basic MSI工程常见问题解答
- C++中虚析构函数的作用
- hibernate annotations OneToMany与ManyToOne 分析
- hibernate annotations OneToMany与ManyToOne 分析
- C++中禁止类被派生的方法
- Sockets编程简介
- 谈谈UDX对多IP的支持
- SSH搭建环境(图文)
- ibatis 使用filter查询
- 在本机搭建Darwin Streaming Server流媒体服务器的debug环境
- 以GPU之名!高性能手机购机指南
- Debian VI高亮显示及注释颜色过灰暗更改办法
- 使用jstl