Effective C++ 4.设计与声明
//条款18:让接口容易被正确使用,不易被误用
// 1.如果客户企图使用某个接口而却没有获得他所预期的行为,那么这个代码就不该通过编译。
// 2.促进正确使用的方法包括接口的一致性,以及与内置类型的行为兼容。
// 3.阻止误用的方法包括建立新类型、限制类型上的操作,束缚对象值,以及消除客户的资源管理责任。
// 4.shared_ptr支持自定义删除器,可以方便的用于管理各种资源。 //条款20:pass by reference to const 替换 pass by value
// 1.C++的底层操作会将传引用操作以指针的形式来实现。
// 2.传递const的引用可以避免父对象接收子对象时候面临的子对象被切割的问题。
// 3.传递const的引用可以有效避免无谓的拷贝和销毁操作,在性能上产生优势
// 4.对于内置类型以及STL的迭代器以及STL中的函数对象,对它们而言传递值比传递引用更加适当。对于此条规则,经vs2010测试发现,传值与传引用几乎没什么差别,所以统一使用传引用代替传值是可以的。 //条款22:将成员变量声明为private
// 1.将成员变量声明为private的,这可以赋予客户访问数据的一致性、可细微划分访问控制、允诺约束条件获得保证,并让类的设计者以充分的实现弹性。
// 2.切记protected并不比public更具封装性。若子类以public方式继承,则可以通过using轻松改变父类中protected成员的访问权限。 //条款23:以非成员函数、非友元函数替换成员函数
// 1.越少的代码可以访问到类的私有成员数据,那么类的私有成员数据的封装性就越好。
// 如下代码:ClearCTestData()函数被声明为类的非成员函数,使得能访问类的私有成员的函数减少,这就提高了类的数据的封装性。如此当改变了类的数据成员的时候,需要被改变的代码量就会减少。
class CTest
{
public:
CTest() : value0(0), value1(0){} public:
void ClearValue0(){value0 = 0;}
void ClearValue1(){value1 = 0;} private:
int value0;
int value1;
}; void ClearCTestData(CTest &Test)
{
Test.ClearValue0();
Test.ClearValue1();
}
// 2.上述的ClearCTestData()系列函数,通常是作为类的辅助工具提供的,将其声明为类的非成员函数,可以降低编译的依存性。 //条款24:若所有参数都可能需要类型转换,那么最好将其声明为类的非成员函数
//1.如下代码:
class CTest
{
public:
CTest (int nTemValue) : value(nTemValue){}
public:
const CTest operator * (const CTest& tem) const {return CTest(value * tem.value);} //此处之所以不是返回一个引用而是按值返回一个对象,是为了防止引用对象不存在的情况。
int GetValue() const {return value;} //为了使得常量对象也能调用此函数,必须将其声明为常量成员函数。
private:
int value;
}; const CTest FunTest(const CTest &tem0, const CTest &tem1)
{
return CTest(tem0.GetValue() * tem1.GetValue());
} CTest Test0(1);
CTest Test1 = Test0 * 2; //允许通过编译
//CTest Test2 = 2 * Test0; //不允许通过编译
//之所以CTest Test1 = Test0 * 2;能通过编译,是因为发生了隐式类型转换,将2转换为CTest类型
//之所以CTest Test2 = 2 * Test0;不能通过编译,是因为只有参数位于参数列表中,这个参数才能发生隐式类型转换。 CTest Test2 = FunTest(2, 2); //允许通过编译,需要隐式转换的参数都位于形参列表中 //条款25:考虑为类写出一个不抛出异常的swap函数
// 1.swap是一个有趣的函数,原本是STL的一部分,而后来成为异常安全性变成的脊柱,以及用来处理自我赋值的可能性。
// 2.当std::swap对自定义的类型效率不高的时候(比如在这个类型中使用了指针指向了一个内存,如此swap应该交换指针而非交换指针所指对象),提供一个swap成员函数,并确定这个函数不抛出异常
// 3.如果提供一个成员函数swap,那么也该提供一个非成员函数版本的swap来调用成员函数版本的swap。
// 4.不要试图往std命名空间中添加新的成员,这种行为是未定义的。
Effective C++ 4.设计与声明的更多相关文章
- 《Effective C++》设计与声明:条款18-条款25
条款18:让接口容易被正确使用,不容易被误用 注意使用const,explicit,shared_ptr等来限制接口. 必要时可以创建一些新的类型,限制类型操作,束缚对象等. 注意保持接口的一致性,且 ...
- 【Effective C++】设计与声明
条款18:让接口容易被正确使用,不易被误用 1,好的接口很容易被正确使用,不容易被误用.你应该在你的所有接口中努力达成这些性质. 2,“促进正使用”的办法包括接口的一致性,以及与内置类型的行为兼容. ...
- Effective C++: 04设计与声明
18:让接口容易被正确使用,不易被误用 1:理想上,如果客户企图使用某个接口而却没有获得他所预期的行为,这个代码不该通过编译:如果代码通过了编译,它的作为就该是客户所想要的. 2:许多客户端的错误可以 ...
- 《Effective C++》第4章 设计与声明(2)-读书笔记
章节回顾: <Effective C++>第1章 让自己习惯C++-读书笔记 <Effective C++>第2章 构造/析构/赋值运算(1)-读书笔记 <Effecti ...
- 《Effective C++》第4章 设计与声明(1)-读书笔记
章节回顾: <Effective C++>第1章 让自己习惯C++-读书笔记 <Effective C++>第2章 构造/析构/赋值运算(1)-读书笔记 <Effecti ...
- 《Effective C++》阅读总结(四): 设计、声明与实现
第四章: 设计与声明 18. 让接口更容易被正确使用,不易被误用 将你的class的public接口设计的符合class所扮演的角色,必要时不仅对传参类型限制,还对传参的值域进一步限制. 19. 设计 ...
- EffectiveC++ 第4章 设计与声明
我根据自己的理解,对原文的精华部分进行了提炼,并在一些难以理解的地方加上了自己的"可能比较准确"的「翻译」. Chapter4 设计与声明 Designs and Declarat ...
- Effective C++笔记:设计与声明
条款18:让接口容易被正确使用,不易被误用 1,好的接口很容易被正确使用,不容易被误用.你应该在你的所有接口中努力达成这些性质. 2,“促进正使用”的办法包括接口的一致性,以及与内置类型的行为兼容. ...
- Effective C++笔记04:设计与声明
条款18:让接口easy被正确使用,不易被误用 1,好的接口非常easy被正确使用,不easy被误用.你应该在你的全部接口中努力达成这些性质. 2,"促进正使用"的办法包含接口的一 ...
随机推荐
- nginx反向代理初探
1.安装nginx 2.在nginx.conf的http区段中配置负载均衡段 #cluserupstream myCluster{ server 192.168.1.110:1300 weight=5 ...
- composer autoload
1.引入autoload 文件 include “vendor/autoload.php” 2.自定义的单文件引入 “autoload”:{ "files":["lib/ ...
- Environment Variables
https://msdn.microsoft.com/en-us/library/windows/desktop/ms682653(v=vs.85).aspx Every process has an ...
- Nobel Lecture, December 12, 1929 Thermionic phenomena and the laws which govern them
http://www.nobelprize.org/nobel_prizes/physics/laureates/1928/richardson-lecture.pdf OWEN W. RICHARD ...
- jq each 用法以及js与json互转
$(function(){ var json = '[{"id":"1","tagName":"apple"},{&qu ...
- Lazarus如何变成XE的界面
先设置: 进入“配置安装的包”,选中 EasyDockMgr 和 easyDockMgrDsgn 这两项,重新编译 Lazarus 吧 修改以后,界面就变成了XE的了:
- http安全篇
一.app与服务端交互确保来源的安全 作为一个移动互联网App,天生是需要和服务器通信的.那么,服务器如何识别客户端的身份?我们如何保证数据传输过程中的安全性?要靠两个东西:使用AppKey做身份识别 ...
- 【转】C# HttpWebRequest\HttpWebResponse\WebClient发送请求解析json数据
http://blog.csdn.net/kingcruel/article/details/44036871 版权声明:本文为博主原创文章,未经博主允许不得转载. ================= ...
- OpenStack,ceph
· Hypervisor或Container项目 · 基础设施即服务(IaaS) · 平台即服务 (PaaS) · 配置管理工具 · 储存服务 (Storage) 在虚拟层类别中,KVM收获了48%的 ...
- ubuntu cpus 共享打印
下载工具 axel 打印机 hp-setup http://blog.x1986.com/t/18.think lsusb wkhtmltopdf/0.12.2.1 ubuntu 14.01 x64下 ...