读书笔记:Effective C++ 2.0 版,条款39(避免向下转换)、条款40(用构成实现有一个和用...实现)

条款39: 避免 "向下转换" 继承层次

从一个基类指针到一个派生类指针 ---- 被称为 "向下转换".

应该使用虚函数替代,避免向下转换。

安全的向下转换,过C++的dynamic_cast运算符(参见条款M2)来实现。

条款40: 通过分层来体现 "有一个" 或 "用...来实现"

使某个类的对象成为另一个类的数据成员,从而实现将一个类构筑在另一个类之上,这一过程称为 "分层"(Layering)。"分层" 这一术语有很多同义词,它也常被称为:构成(composition),包含(containment)或嵌入(embedding)。

c 复制代码
class Address { ... }; 
class PhoneNumber { ... };
class Person {
public:
private:
  string name;                   // 下层对象
  Address address;               // 同上
  PhoneNumber voiceNumber;       // 同上
  PhoneNumber faxNumber;         // 同上
};

list实现有序set

c 复制代码
template<class T>
class Set {
public:
  bool member(const T& item) const;
  void insert(const T& item);
  void remove(const T& item);
  int cardinality() const;
private:
  list<T> rep;// 表示一个Set
};
相关推荐
叶子野格5 分钟前
《C语言学习:数组》11
c语言·开发语言·c++·学习·visual studio
Little At Air9 分钟前
C++priority_queue模拟实现
开发语言·数据结构·c++
程序员zgh10 分钟前
C++ decltype 关键字 详解
c语言·开发语言·c++
乐观勇敢坚强的老彭22 分钟前
C++信奥洛谷循环章节练习题
java·c++·算法
Shingmc322 分钟前
【Linux】序列化与反序列化
开发语言·c++
白夜111735 分钟前
C++设计模式(高内聚,低耦合)
c++·设计模式
我不是懒洋洋38 分钟前
【数据结构】二叉树-堆(树的概念、二叉树的概念、顺序结构的结构及实现、堆的实现、堆排序、TopK问题)
c语言·数据结构·c++·经验分享·算法·青少年编程
ximu_polaris38 分钟前
设计模式(C++)-结构型模式-桥接模式
c++·设计模式·桥接模式
楼田莉子39 分钟前
仿muduo库的高并发服务器——正则表达式与any类介绍及其简单模拟实现
linux·服务器·c++·学习·设计模式
wengqidaifeng2 小时前
C++从菜鸟到强手:1.基础入门
开发语言·c++