任何接口设计的一个准则:让接口容易被正确使用,不容易被误用。
理想上:如何客户企图使用某个接口缺没有获得他所预期的行为,这个代码不该通过编译;如果代码通过了编译,他的行为就该是客户所想要的。
1. 导入外覆类型(wrapper types)
2. 让types容易被正确使用,不容易被误用。尽量领你的types行为与内置types一致。
3. 设计class犹如设计type
新type的对象应该如何被创建和销毁?(自己设计operatornew,operatornew[],operator delete和operator delete[])
对象的初始化和对象的复制该有什么样的差别?对应于不同的函数调用
新type的对象如果被passed by value ,意味着什么
什么是新type的“合法值”?(??)
你的新type需要配合某个继承图系吗?
你的心type需要什么样的转换
什么样的操作符合函数对此新type而言是合理的
什么样的标准函数应该驳回
谁该取用新type的成员
什么是新type的未声明接口
你的新type有多么一般化
你真的需要一个新type吗
一、宁以pass-by-reference-to-const 替换 pass-by-value
1.tbw效率高,没有任何构造函数或析构函数被调用,因为没有任何新对象被创建。
2. by refrenece方式传递参数还可以避免对象slicing 问题
二、必须返回对象时,别妄想返回其reference
所有用上static对象的设计,会造成多线程安全性的怀疑。
三、将成员变量声明为private:
1. 可以实现出“不准访问”、“只读访问”、“读写访问”、“惟写访问”
2. 封装:它使我们能够改变事物而只影响有限客户。
将成员变量隐藏在函数接口的背后,可以为“所有可能的实现”提供弹性。如:tb变量被读或被写时通知其他对象、可以验证class的约束条件以及函数的前提和事后转帖;以及在多线程环境执行同步控制。。。。等。
四、宁以non-member、non-friend替换member函数
- namespace WebBrowserStuff{
- class WebBrowser{...};
- void clearBrowser(WebBrowser& wb);
- }
五、若所有参数皆需要类型转换,请为此采用non-member函数
- class Rational {
- ...
- }
-
- const Rational operator*(const Rational& lhs,const Rational& rhs)
- {
- return Rational( lhs.numerator()* rhs.numerator()
- ,lhs.denominator()*rhs.denominator() );
- }
-
- Rational oneFourth(1,4);
- Rational result;
- result = oneFourth * 2;
- result = 2*oneFourth;
六、考虑写出一个不抛异常的swap函数