<<More Effective C++>>读书笔记6: 杂项

《More Effective C++》+《Effective C++》,两本经典双剑合璧,必然威力无穷。


    Item M32:在未来时态下开发程序
1. 用C++语言自己来表达设计上的约束条件,而不是用注释或文档。
   [很好的思想,但需要熟练掌握C++特性]
2. 因为万物都会变化,要写能承受软件发展过程中的混乱攻击的类。
3. 要使得自己的类易于被正确使用而难以误用。
4. 如果一个公有基类没有虚析构函数,所有的派生类基其成员函数都不应该有析构函数。
   如果多重继承体系有许多析构函数,每个基类都应该有应该虚析构函数。
5. 未来时态的考虑认为:如果一个类被设计为作一个基类使用(即使现在还没有被这么使用),它就应该有一个虚析构函数。这样的类在现在和将来都行为正确,并且当新类从它们派生时并不影响其它库用户。
   [未来时态的考虑增加代码的可重用性、可维护性、健壮性,已及在环境发生改变时易于修改(跨平台)。它必须与进行时态的约束条件进行取舍。太多的程序员们只关注于现在的需要,然而这么做牺牲了软件的长期生存能力。]

    Item M33:将非尾端类设计为抽象类
1. C++的强类型原则将评定混合类型赋值非法;然而,通过将“基类”的赋值操作设为虚函数,我们打开了混合类型操作的门。
   [我们应该允许通过指针进行同类型赋值,而禁止通过同样的指针进行混合类型赋值。]
2. 在运行期使用dynamic_cast 进行类型检测,这个函数复杂并且昂贵--dynamic_cast 将引用一个type_info 结构。
3. 绝大部分纯虚函数都没有实现,但纯虚析构函数是个特例,它们必须被实现(因为它们在派生类析构函数被调用时也将被调用),将析构函数设为“纯虚”的唯一麻烦就是必须在类的定义之外实现它。
4. 从一个无数据的实体类派生新的实体类是安全的。
5. 只有在设计出的类能被将来的类从它继承而不需要它作任何修改时,你才能从数据包的抽象类中获得好处。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值