问题聚焦:
    这一节不涉及代码,但是我们需要明确的一点是,思想比代码要重要得多。
    设计优秀的classes是一项艰巨的工作,就像设计好的types一样。
    我们应该带着和“语言设计者当初设计语言内置类型时”一样的谨慎来研讨class的设计。

那么,如何设计高效的classes呢?
下面几乎每一个针对class设计的提问,往往就是你所需要遵守的设计规范。
1 新type的对象应该如何被创建和销毁?
    这会影响到你的class的构造函数和析构函数以及内存分配函数和释放函数的设计。
2 对象的初始化和对象的赋值该有什么样的差别?
    这个答案决定你的构造函数和赋值操作符的行为,以及其间的差异。
    很重要的一点:别混淆了“初始化”和“赋值”,因为它们对应于不同的函数调用。
3 新type的对象如果被passed by value,意味着什么?
    记住,拷贝构造函数用来定义一个type的pass-by-value该如何实现。
4 什么是新type的合法值?
    对class的成员变量而言,通常只有某些值集是有效的。
    那些值集决定了你的class:
  • 必须维护的约束条件
  • 决定了你的成员函数必须进行的错误检查工作
  • 影响函数抛出的异常
  • 函数异常明细列表

5 你的新type需要配合某个继承图系吗?

    如果你继承自某些既有的classes,你就受那些classes的设计的束缚,特别是受到它们的函数是virtual或non-virtual的影响。
    如果你允许其他classes继承你的class,那会影响你所声明的函数,尤其是析构函数。
6 你的新type需要什么样的转换?
    你的type生存于其他一堆types之间,因此彼此该有转换行为吗?
    如果你希望允许类型T1被隐式转换为类型T2,就必须在class T1内写一个类型转换函数或在class T2内写一个non-explicit-one-arument的构造函数。
7 什么样的操作符和函数对此新type而言是合理的?
    这个问题的答案决定你将为你的class声明哪些函数。其中某些该是member函数,某些则不是。
8 什么样的标准函数应该被驳回?
    那些正是你必须声明为private的函数。
9 谁该取用新type的成员?
    这个提问可以帮你你决定哪个成员为public,哪个为protected,哪个为private。
    它也帮助你决定哪一个classes和/或functions应该是friends,以及将它们嵌套于另一个之内是否合理。
10 什么是新type的“未声明接口”?
    它对效率,异常安全性以及资源运用提供何种保证?
    你在这些方面提供的保证将成为你的class实现代码加上相应的约束条件。
11 你的新type有多么一般化?
    或许你其实并非定义一个新type,而是定义个整个types家族。果真如此,你就不应该定义一个新class,而是应该定义一个新的class template。
12 你真的需要一个新type吗?
    如果只是定义新的derived class 以便为既有的class 加机能, 那么说不定单纯定义一或多个non-member函数或templates,更能打到目标。
这些问题不容易回答,所以定义出高效的classes是一种挑战。

小结:
class 的设计就是type的设计。
在定义一个新type或class之前,请认真考虑本节的12个问题。
参考资料:
《Effective C++ 3rd》

Effective C++(19) 设计class犹如设计type的更多相关文章

  1. Effective C++ -----条款19:设计class犹如设计type

    Class的设计就是type的设计.在定义一个新type之前,请确定你已经考虑过本条款覆盖的所有讨论主题. 新type的对象应该如何被创建和销毁? 对象的初始化和对象的赋值该有什么样的区别? 新typ ...

  2. 条款19:设计class犹如设计TYPE(Treat class design as type design)

    NOTE: 1.Class 的设计就是type的设计.在定义一个新type之前,请确认自己已经考虑过本条款所有主题(具体参考effective c++).

  3. EC笔记:第4部分:19、设计class犹如设计type

    设计一个class,应该考虑以下问题: 新type的对象应该怎样创建和销毁? 构造函数 析构函数 内存分配 内存释放 对象的初始化和对象的赋值应该有什么样的差别? 拷贝构造函数 赋值运算符 新对象如果 ...

  4. 【19】设计class犹如设计type

    设计class 的时候,需要好好考虑下面的问题: 1.新type的对象应该如何被创建和销毁? 2.对象的初始化和对象的赋值该有什么样的差别? 3.新type的对象如果pass by value,意味着 ...

  5. [Effective C++ --019]设计class犹如设计type

    前言 我们在编写程序的时候,无论哪一种语言,总是会告诉你这种语言应该有的类型.我们将它们直接拿来使用,可是从来没有考虑过这些类到底是怎么设计出来的! 所幸的是:在OOP中,每当我们定义一个新的clas ...

  6. 条款19:设计class犹如设计type

    1,新的type对象应该如何被创建和销毁? 这会影响class的构造函数ctor和析构函数dtor,以及内存分配函数和释放函数   //operator new //operator new[] // ...

  7. 《Effective C++》第4章 设计与声明(1)-读书笔记

    章节回顾: <Effective C++>第1章 让自己习惯C++-读书笔记 <Effective C++>第2章 构造/析构/赋值运算(1)-读书笔记 <Effecti ...

  8. Effective C++笔记(四):设计与声明

    参考:http://www.cnblogs.com/ronny/p/3747186.html 条款18:让接口容易被正确使用,不易被误用 1,好的接口很容易被正确使用,不容易被误用.你应该在你的所有接 ...

  9. 《Effective C++》第4章 设计与声明(2)-读书笔记

    章节回顾: <Effective C++>第1章 让自己习惯C++-读书笔记 <Effective C++>第2章 构造/析构/赋值运算(1)-读书笔记 <Effecti ...

随机推荐

  1. 采用xshell链路本地虚拟机Linux

    昨天想安装在自己的机器看Linux.而使用xshell通路.但是这花了很长的时间,于xshell结束所有的提示"Could not connect to '192.168.54.100' ( ...

  2. 开展project 正常的生活之路

    相对刚走出学校的学生在其他行业工作,竞争力的薪酬,同时.并不断地不仅学习更新专业知识让你感到生活的充实,更满足了你那不让外人知的虚荣心.在刚出校门的几年中,你常常回头看看被你落在后面的同学们,在内心怜 ...

  3. SSIS从理论到实战,再到应用(7)----常用的数据类型转换操作

    原文:SSIS从理论到实战,再到应用(7)----常用的数据类型转换操作 上期回顾: SSIS从理论到实战,再到应用(6)----SSIS的自带日志功能 在抽取各种应用的数据时候,经常会遇到数据需要转 ...

  4. Linux/Unix

    Linux/Unix 新手和专家教程 你正在找一些高质量的Linux 和 UNIX 的教程吗?如果是,这篇文章会告诉你到哪去找到这些教程.这里我们将给出超过30个相当的不错的 Linux 和 UNIX ...

  5. ASP.NET MVC+EF框架+EasyUI实现权限管理系列(4)-业务逻辑层的封装

    原文:ASP.NET MVC+EF框架+EasyUI实现权限管理系列(4)-业务逻辑层的封装 ASP.NET MVC+EF框架+EasyUI实现权限管系列 (开篇)   (1):框架搭建    (2) ...

  6. javascript系列之DOM(一)

    原文:javascript系列之DOM(一) DOM(document object moudle),文档对象模型.它是一个中立于语言的应用程序接口(API),允许程序访问并修改文档的结构,内容和样式 ...

  7. crawler_http关闭连接

    1:ps aux|grep Spider4Test.jar 查看端口 2: lsof  -p [端口号] 在爬虫运行期间如果看到 大量的 TIME_WAIT  WAIT_CLOSE 说明请求关闭阻塞[ ...

  8. javascript的语法作用域你真的懂了吗

    原文:javascript的语法作用域你真的懂了吗 有段时间没有更新了,思绪一下子有点转不过来.正应了一句古话“一天不读书,无人看得出:一周不读书,开始会爆粗:一月不读书,智商输给猪.”.再加上周五晚 ...

  9. Tomcat剖析(一):一个简单的Web服务器

    Tomcat剖析(一):一个简单的Web服务器 1. Tomcat剖析(一):一个简单的Web服务器 2. Tomcat剖析(二):一个简单的Servlet服务器 3. Tomcat剖析(三):连接器 ...

  10. Openstack &amp; Hadoop结合项目Sahara

    Openstack 项目Sahara,主要是用来搭建Hadoop集群,利用虚拟出来的计算资源,高速搭建Hadoop集群. Sahara项目与OPenstack其它项目的关系: 图片转自:http:// ...