C++ primer plus读书笔记——第10章 对象和类
第10章 对象和类
1. 基本类型完成了三项工作:
决定数据对象需要的内存数量;
决定如何解释内存中的位;
决定可使用数据对象执行的操作或方法。
2. 不必在类声明中使用关键字private,因为这是类对象的默认访问控制机制。
3. 其定义位于类声明中的函数都将自动成为内联函数。
4. 如果愿意,也可以在类声明之外定义成员函数,并使其称为内联函数。为此,只需要在类实现部分定义函数时使用inline限定符即可。
5. 内联函数的特殊规则要求在每个使用它们的文件中都对其进行定义。确保内联定义对多文件程序中的所有文件都可用的、最简便的方法是:将内联定义放在定义类的头文件中。(内联函数应该放在头文件中)
6. 设置显示的小数位数和恢复:
std::streamsize prec = std::cout.precision(3);//显示3位小数
…
std::cout.precision(prec);
设置定点表示,避免使用科学计数法:
using std::ios_base;
ios_base::fmtflags orig = cout.setf(ios_base::fixed, ios_base::floatfield);
…
cout.setf(orig, ios_base::floatfield);
7. 构造函数没有返回值,但没有被声明为void类型。
构造函数参数名不能与类成员相同。
8. 隐式调用构造函数:
Stock food(“World Cabbage”, 250, 1.25);
显式调用构造函数:
Stock food = Stock(“World Cabbage”, 250, 1.25);
和new一起使用:
Stock *pstock = new Stock(“World Cabbage”, 250, 1.25);
9. 默认构造函数
当且仅当没有定义任何构造函数时,编译器才会提供默认构造函数。为类定义了构造函数后,程序员就必须提供默认构造函数了。否则,下面的定义将出错:
Stock stock1;
定义默认构造函数的方式有两种。一种是给已有构造函数的所有参数提供默认值。另一种是通过函数重载来定义一个没有参数的构造函数。
10. 调用默认构造函数的方式:
Stock first;
Stock first = Stock();
Stock *pstock = new Stock;
然而,不要被非默认构造函数的隐式形式所误导:
Stock second();
second是一个返回Stock对象的函数。隐式地调用默认构造函数时,不要加圆括号。
11. 析构函数的名称很特殊:在类名前加上~。析构函数没有返回值和参数。
12. 由于自动变量被放在栈中,因此最后创建的对象最先被删除,最先创建的对象最后被删除。
13. 下面两条语句有根本性的差别。
Stock stock2 = Stock(“Boffo Object”, 2, 2.0);//初始化,可能会创建一个临时对象。
Stock stock1;
stock1 = Stock(“Boffo Object”, 2, 2.0);//赋值,一定会创建一个临时对象。
14. const Stock land = Stock(“Boffo Object”, 2, 2.0);
land.show();//这一行如果show()不是const成员函数,将出错。
由于该方法所使用的对象是隐式地提供的,没办法使用const引用或指向const的指针来解决问题。为了让函数保证不会修改调用对象,C++的解决方法是将const关键字放在函数的括号后面。也就是说,show()的声明应像这样:
void show() const;
同样,函数定义的开头应像这样:
void Stock::show() const{…};
15. 如果编译器支持C++11,则可使用列表初始化:
Bozo bozetta = {“Bozetta”, “Biggens”};
Bozo bozetta{“Bozetta”, “Biggens”};
Bozo *pc = new Bozo{“Bozetta”, “Biggens”};
16. 接受一个参数的构造函数允许使用赋值语法将对象初始化为一个值:
Classname object = value;
这种特性可能导致问题,正如第11章将介绍的,可关闭这项特性。
17. this指针指向用来调用成员函数的对象(this被作为隐藏参数传递给方法)。在函数的括号后面使用const限定符将this限定为const,这样不能使用this来修改对象的值。
18. C++在创建对象前,并没有用于存储值的空间,因此如下定义是行不通的:
class Bakery
{
private:
const int Months = 12;
double costs[Months];
…
有两种方式可以实现这个目标。
第一种方式使用枚举:
class Bakery
{
private:
enum {Months = 12};
double costs[Months];
…
用这种方式声明枚举并不会创建类数据成员,所有对象中都不包含枚举。Months只是一个符号名称。
由于这里使用枚举只是为了创建符号常量,并不打算创建枚举类型的变量,因此不需要提供枚举名。这种方法很常用,诸如ios_base::fixed就是ios_base类中定义的典型的枚举量。
第二种方式是使用static关键字:
class Bakery
{
private:
static const int Months = 12;
double cost[Months];
…
该静态常量将和其它的静态变量存储在一起,而不是存储在对象中。因此,只有一个Months常量,被所有Bakery对象共享。
19. 作用域内枚举(C++11)
传统的枚举存在一些问题,其中之一就是两个枚举定义的枚举量可能发生冲突。为避免这种问题,C++11提供了一种新枚举,其枚举量的作用域为类。
enum egg {Small, Medium, Large, Jumbo};
enum t_shirt {Small, Medium, Large, Xlarge};
这将无法通过编译,因为egg Small和t_shirt Small位于相同的作用域内,它们将发生冲突。为了避免这种问题,C++11提供了一种新枚举,其枚举量的作用域为类。如下:
enum class egg{ Small, Medium, Large, Jumbo };
enum class t_shirt{Small, Medium, Large, Xlarge};
也可以使用关键字struct代替class,但无论使用哪种方式,都需要使用枚举名来限制枚举量:
egg choice = egg::Large;
t_shirt Floyd = t_shirt::Large;
该注意的是,作用域内枚举不能隐式地转换为整形,在必要时,可以进行显式类型转换。普通枚举的底层整形类型表示取决于实现。对于作用域内枚举,C++11规定它的底层类型为int。还提供了一种语法,可用于做出不同的选择:
enum class : short pizza {Small, Medium, Large, XLarge};
在C++11中,也可以使用这种语法指定常规枚举的底层类型,但如果没有指定,编译器选择的底层类型随实现而异。
20. 类很适用于描述ADT。公有成员函数借口提供了ADT描述的服务,类的私有部分和类方法的代码提供了实现,这些实现对类的客户隐藏。
C++ primer plus读书笔记——第10章 对象和类的更多相关文章
- C++ Primer Plus读书笔记(十)对象和类
1.类 不废话,上定义 class ClassName { public: xxx; private: xxx; protected: xxx; } private部分数据只能通过public 提供的 ...
- 《C++ Primer 4th》读书笔记 第10章-关联容器
原创文章,转载请注明出处:http://www.cnblogs.com/DayByDay/p/3936464.html
- C primer plus 读书笔记第五章
本章的标题是运算符,表达式和语句.主要研究如何处理数据. 示例代码展示了一个使用简单的while循环的代码,难度不大. 下面简单介绍本章的基本概念. 1.基本运算符. 基本运算符有:赋值运算符(C语言 ...
- 《JavaScript Dom 编程艺术》读书笔记-第10章
用JS实现动画~内容包括: 1. 动画基础知识 2. 用动画丰富网页的浏览效果 动画就是让元素的位置随时间而不断变化. 位置: //CSSelement{ position:absolute; top ...
- $《第一行代码:Android》读书笔记——第10章 Android网络编程
(一)WebView的用法 1.WebView也是一个普通的控件. 2.常用用法: WebView webView = (WebView)findViewById(R.id.web_view); we ...
- C++ primer plus读书笔记——第17章 输入、输出和文件
第17章 输入.输出和文件 1. 对键盘进行输入缓冲可以让用户在将输入传输给程序之前返回并更正.C++程序通常在用户按下回车键时刷新输入缓冲区. 2. 一些I/O类 streambuf类为缓冲区提供了 ...
- C++ primer plus读书笔记——第16章 string类和标准模板库
第16章 string类和标准模板库 1. string容易被忽略的构造函数: string(size_type n, char c)长度为n,每个字母都为c string(const string ...
- C++ primer plus读书笔记——第15章 友元、异常和其他
第15章 友元.异常和其他 1. 友元类的所有方法都可以访问原有类的私有成员和保护成员.另外,也可以做更严格的限制,只将特定的成员函数指定为另一个类的友元.哪些函数.成员函数.或类为友元是由类定义的, ...
- C++ primer plus读书笔记——第14章 C++中的代码重用
第14章 C++中的代码重用 1. 使用公有继承时,类可以继承接口,可能还有实现(基类的纯虚函数提供接口,但不提供实现).获得接口是is-a关系的组成部分.而使用组合,类可以获得实现,但不能获得接口. ...
随机推荐
- P1604_B进制星球(JAVA语言)
思路:BigInteger 五杀!利用BigInteger自带的进制转换. //第一次提交WA了几组数据,下载测试数据发现带字母的答案要转换为大写. 题目背景 进制题目,而且还是个计算器~~ 题目描述 ...
- 攻防世界 reverse hackme
hackme XCTF 3rd-GCTF-2017 __int64 __fastcall sub_400F8E(__int64 a1, __int64 a2) { char input[136]; / ...
- Mysql之索引选择及优化
索引模型 哈希表 适用于只有等值查询的场景,Memory引擎默认索引 InnoDB支持自适应哈希索引,不可干预,由引擎自行决定是否创建 有序数组:在等值查询和范围查询场景中的性能都非常优秀,但插入和删 ...
- 推荐一款全能测试开发神器:Mockoon!1分钟快速上手!
1. 说一下背景 在日常开发或者测试工作中,经常会因为下游服务不可用或者不稳定时,通过工具或者技术手段去模拟一个HTTP Server,或者模拟所需要的接口数据. 这个时候,很多人脑海里,都会想到可以 ...
- Nacos 2.0 正式发布,性能提升了 10 倍!!
前不久,在3月20号,Nacos 2.0.0 正式发布了!我简单看了下官方的介绍,可能nacos未来逐渐会成为各大公司作为服务治理和配置中心的主要中间件. Nacos 简介:一个更易于构建云原生应用的 ...
- PReact10.5.13源码理解之hook
hook源码其实不多,但是实现的比较精巧:在diff/index.js中会有一些optison.diff这种钩子函数,hook中就用到了这些钩子函数. 在比如options._diff中将curr ...
- nginx 本地配置(解决跨域问题)
前端做跨域本身就是扯淡的事情.后台人员不配合说什么都是白搭.索性整理了一下心得,(可以直接部署自配置)发不多说上代码: 1 #user nobody; 2 worker_processes 1; 3 ...
- [Fundamental of Power Electronics]-PART II-8. 变换器传递函数-8.2 变换器传递函数分析
8.2 变换器传递函数分析 接下来,让我们推导基本变换器传递函数中的极点,零点和渐近线增益的解析表达式. 8.2.1 示例:Buck-boost变换器的传递函数 Buck-boost变换器的小信号等效 ...
- OO_Unit2 关于性能优化与测试的那些事
OO_Unit2 关于性能优化与测试的那些事 OO的第2单元到本周也就正式完结了.尽管这个单元的主旋律是多线程,但"面向对象"的基本思想仍然是我们一切架构与优化的出发点与前提.因此 ...
- DDD实战让中台和微服务的落地如虎添翼
微服务到底怎么拆分和设计才算合理,拆多小才叫微服务?有没有好的方法来指导微服务和中台的设计呢? 深入DDD的核心知识体系与设计思想,带你掌握一套完整而系统的基于DDD的微服务拆分与设计方法,助力落地边 ...