如何在C++中实现java final标识的类的功能
2015-08-02 17:48
323 查看
Java中被final关键字标识的对象或者变量往往都意味着不能在运行时被动态更改,final的类则无法被继承。在C++中,变量可以用const声明为常量来表示相同的效果,而关于类的继承限制似乎没有相应的关键字予以实现,但借助于目前C++的相关机制,是能够手动实现final类的功能的,相关代码如下:
这里的虚继承是C++多重继承机制所特有的关键字,它可以保证子类必定调用父类的构造函数,并且其多个子类是共享同一个父类的构造函数。
主要的思想就是利用友元类的特性,使得final类可以访问其父类的构造函数,但由于友元特性是不能被继承的,因此其子类没有权限访问其基类的私有方法,最终实现final的功能,这样能够避免将基类构造方法定义为私有所导致的子类对象无法访问构造函数的情况,的确是一种非常巧妙的思路。
#include <iostream> #include <string> #include <vector> #include <stack> #include <map> using namespace std; template <typename T> class MakeFriend { public: typedef T type; }; template <typename T> class MakeFinal { friend class MakeFriend<T>:: type;//通过模板类封装友元类T private: MakeFinal(){}; ~MakeFinal(){}; }; class FinalClass :virtual public MakeFinal<FinalClass>//通过虚继承实现的具有final关键字的类FinalClass 虚继承保证了必定会调用父类的构造函数 { }; class TestFinalClass : public FinalClass { }; int main() { //TestFinalClass tfc; TestFinalClass *tfc = new TestFinalClass();//出现编译错误,因为试图使用子类去调用父类的私有构造函数 FinalClass *fc = new FinalClass;//成功编译,在堆上分配资源 system("pause"); return 0; }
这里的虚继承是C++多重继承机制所特有的关键字,它可以保证子类必定调用父类的构造函数,并且其多个子类是共享同一个父类的构造函数。
主要的思想就是利用友元类的特性,使得final类可以访问其父类的构造函数,但由于友元特性是不能被继承的,因此其子类没有权限访问其基类的私有方法,最终实现final的功能,这样能够避免将基类构造方法定义为私有所导致的子类对象无法访问构造函数的情况,的确是一种非常巧妙的思路。
相关文章推荐
- 安迪的第一个字典
- C语言——单线程播放多音乐和一些小方法
- c++学习笔记(部分语法及c++11新特性)
- C语言:通过指针对数组元素进行排序
- Where is the Marble?
- c++ enum类型常量
- C语言编程入门——指针与函数、数组
- C语言编程入门——指针(下)
- cpp整理学习笔记 文件I/O:随机存取fseek()和ftell()
- C++函数
- C++ 常见面试题目 (二)
- C语言编程入门——指针(上)
- C++对象模型——Data 语意学(第三章)
- C语言:通过返回指针的形式找出数组的最大值和最小值
- [C++] 分享国外程序员的 C++开发资源大全
- C语言:链队列
- C语言编程入门——函数(下)
- C++标准模板库集合类与映射类总结
- C语言编程入门——函数(上)
- C++ 使用数组 初始化 Vector