《C++ Primer Plus》学习笔记6

《C++ Primer Plus》学习笔记6

第11章 使用类

<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<

1、操作符的重载

将两个数组相加是一个常见的运算,可以使用下面的for循环来实现

for(int i = 0; i < 20; i++)
    evening[i] = sam[i] + janet[i];//每个元素每个元素相加

在C++中可以定义一个表示数组的类,并重载+操作符

evening = sam + janet;

要重载操作符,需要使用被称为操作符函数的特殊函数形式

operator op (argument-list)

其中op是将要重载的操作符,operator + ()重载+操作符;operator *
()重载*操作符

op必须要是有效的C++的操作符,不能虚拟一个新的符号。

district2 = sid + sara;
district2 = sid.operator + (sara);//隐式地使用了sid,因为它调用了方法,显式地使用sara对象

2、计算时间:一个操作符重载范例

//Time类提供了用于调整和重新设置时间、显示时间并将两个时间相加的方法
#ifndef MYTIME0_H_
#define MYTIME0_H_
class Time
{
private:
    int hours;
    int minutes;
public:
    Time();
    Time(int h, int m = 0);
    void AddMin(int m);
    void AddHr(int h);
    void Reset(int h = 0, int m = 0);
    Time Sum(const Time & t)const;
    //Time operator+ (const Time & t) const;
    void Show()const;
};
#endif

<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<

//mytime0.cpp
#include <iostream>
#include "mytime0.h"

Time::Time()
{
    hours = minutes = 0;
}

Time::Time(int h, int m)
{
    hours = h;
    minutes = m;
}

void Time::AddMin(int m)
{
    minutes += m;
    hours += minutes/60;
    minutes %= 60;
}

void Time::AddHr(int h)
{
    hours += h;
}

void Time::Reset(int h, int m)
{
    hours = h;
    minutes = m;
}

Time Time::Sum(const Time & t)const
//Time Time::operator + (const Time & t)const
{
    Time sum;
    sum.minutes  = minutes + t.minutes;
    sum.hours = hours + t.hours + sum.minutes/60;
    sum.minutes %= 60;
    return sum;
}

void Time::Show() const
{
    std::cout << hours << " hours, " << minutes << " minutes";
}

<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<

//对Time类中计算时间总和的部分进行测试.cpp
#include <iostream>
#include "mytime0.h"

int main()
{
    using std::cout;
    using std::endl;

    Time planning;
    Time coding(2,40);
    Time fixing(5,55);
    Time total;

    cout << "planning time = ";
    planning.Show();
    cout << endl;

    cout << "coding time = ";
    coding.Show();
    cout << endl;

    cout << "fixing time = ";
    fixing.Show();

    total = coding.Sum(fixing);
    cout << "coding.Sum(fixing) = ";
    //操作符方法
    //total = coding + fixing;
    //cout << "coding + fixing = ";

    //函数方法
    //total = coning.operator + (fixing);
    //cout << "coding.operator + (fixing) = ";

    total.Show();
    cout << endl;

    return 0;
}

如果是将两个以上的对象相加:

t4 = t1.operator + (t2.operator + (t3));

3、友元简介

一般来说,访问私有类成员的惟一方法是使用类方法,C++使用友元函数避开这种限制。

C++提供了另一种形式的访问权限:友元

1)友元有三种:友元函数、友元类、友元成员函数

2)当为类重载二元操作符时,带两个参数的操作符,常常需要友元

3)创建友元

创建友元函数

第一步是将其原型放在类声明中,并在原型声明前加上关键字friend:

friend Time operator* (double m, const Time & t);

第二步是编写函数定义,因为它不是成员函数,所以不要使用Time::限定符,另外,不要再定义中使用关键字friend

Time operator* (double m, const Time & t)
{
    Time result;
    long totalminutes = t.hours * mult * 60 + t.minutes * mult;
    result.hours = totalminutes / 60;
    result.minutes = totalminutes % 60;
    return result;
}

类的友元函数是非成员函数,其访问权限与成员函数相同。

4)如果要为类重载操作符,并将非类的项作为其第一个操作数,则可以用友元函数来反转操作数

Time operator * (double m, const Time & t)
{
    return t * m;
}

4、重载操作符:作为成员函数还是非成员函数

1)对于很多操作符来说,可以选择使用成员函数或非成员函数来实现操作符重载,一般来说,非成员函数应是友元函数,这样它才能直接访问类的私有数据

2)Time类加法操作符在Time类声明中的原型如下:

Time operator+(const Time & t)const;//成员函数版本
friend Time operator+ (const Time & t1, const Time & t2);//非成员函数版本

我们可以知道成员函数版本,所需要的参数数目少一个,因为其中的一个操作数是被隐式地传递的调用对象,非成员函数版本则需要形参数目与操作符使用的操作数目相同。

经验告诉我们,尤其在类设计中,我们使用非成员函数版本比较好些

5、类的自动转换和强制类型转换

1)初始化类对象

Stonewt pavarotti = 260;//当构造函数只接收一个参数时
Stonewt pavarotti(260);//当构造函数接收多个参数时候
Stonewt pavarotti = Stonewt(260);//当构造函数接收多个参数时候

2)构造函数只用于从某种类型到类类型的装换,要进行相反的转换,必须使用特殊的C++操作符函数——转换函数。

转换函数

operator typeName();

注意一下几点:

①转换函数必须是类方法

②转换函数不能指定返回类型

③转换函数不能有参数

《C++ Primer Plus》学习笔记6

时间: 2024-10-05 23:25:25

《C++ Primer Plus》学习笔记6的相关文章

vector 学习笔记

vector 使用练习: /**************************************** * File Name: vector.cpp * Author: sky0917 * Created Time: 2014年04月27日 11:07:33 ****************************************/ #include <iostream> #include <vector> using namespace std; int main

Caliburn.Micro学习笔记(一)----引导类和命名匹配规则

Caliburn.Micro学习笔记(一)----引导类和命名匹配规则 用了几天时间看了一下开源框架Caliburn.Micro 这是他源码的地址http://caliburnmicro.codeplex.com/ 文档也写的很详细,自己在看它的文档和代码时写了一些demo和笔记,还有它实现的原理记录一下 学习Caliburn.Micro要有MEF和MVVM的基础 先说一下他的命名规则和引导类 以后我会把Caliburn.Micro的 Actions IResult,IHandle ICondu

jQuery学习笔记(一):入门

jQuery学习笔记(一):入门 一.JQuery是什么 JQuery是什么?始终是萦绕在我心中的一个问题: 借鉴网上同学们的总结,可以从以下几个方面观察. 不使用JQuery时获取DOM文本的操作如下: 1 document.getElementById('info').value = 'Hello World!'; 使用JQuery时获取DOM文本操作如下: 1 $('#info').val('Hello World!'); 嗯,可以看出,使用JQuery的优势之一是可以使代码更加简练,使开

[原创]java WEB学习笔记93:Hibernate学习之路---Hibernate 缓存介绍,缓存级别,使用二级缓存的情况,二级缓存的架构集合缓存,二级缓存的并发策略,实现步骤,集合缓存,查询缓存,时间戳缓存

本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱好者,互联网技术发烧友 微博:伊直都在0221 QQ:951226918 -----------------------------------------------------------------------------------------------------------------

Activiti 学习笔记记录(三)

上一篇:Activiti 学习笔记记录(二) 导读:上一篇学习了bpmn 画图的常用图形标记.那如何用它们组成一个可用文件呢? 我们知道 bpmn 其实是一个xml 文件

HTML&CSS基础学习笔记8-预格式文本

<pre>标签的主要作用是预格式化文本.被包围在 pre 标签中的文本通常会保留空格和换行符.而文本也会呈现为等宽字体. <pre>标签的一个常见应用就是用来表示计算机的源代码.当然你也可以在你需要在网页中预显示格式时使用它. 会使你的文本换行的标签(例如<h>.<p>)绝不能包含在 <pre> 所定义的块里.尽管有些浏览器会把段落结束标签解释为简单地换行,但是这种行为在所有浏览器上并不都是一样的. 更多学习内容,就在码芽网http://www.

java/android 设计模式学习笔记(14)---外观模式

这篇博客来介绍外观模式(Facade Pattern),外观模式也称为门面模式,它在开发过程中运用频率非常高,尤其是第三方 SDK 基本很大概率都会使用外观模式.通过一个外观类使得整个子系统只有一个统一的高层的接口,这样能够降低用户的使用成本,也对用户屏蔽了很多实现细节.当然,在我们的开发过程中,外观模式也是我们封装 API 的常用手段,例如网络模块.ImageLoader 模块等.其实我们在开发过程中可能已经使用过很多次外观模式,只是没有从理论层面去了解它. 转载请注明出处:http://bl

[原创]java WEB学习笔记48:其他的Servlet 监听器:域对象中属性的变更的事件监听器 (3 个),感知 Session 绑定的事件监听器(2个)

本博客为原创:综合 尚硅谷(http://www.atguigu.com)的系统教程(深表感谢)和 网络上的现有资源(博客,文档,图书等),资源的出处我会标明 本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱好者,互联网技术发烧友 微博:伊直都在0221 QQ:951226918 ---------------------------------

java/android 设计模式学习笔记(10)---建造者模式

这篇博客我们来介绍一下建造者模式(Builder Pattern),建造者模式又被称为生成器模式,是创造性模式之一,与工厂方法模式和抽象工厂模式不同,后两者的目的是为了实现多态性,而 Builder 模式的目的则是为了将对象的构建与展示分离.Builder 模式是一步一步创建一个复杂对象的创建型模式,它允许用户在不知道内部构建细节的情况下,可以更精细地控制对象的构造流程.一个复杂的对象有大量的组成部分,比如汽车它有车轮.方向盘.发动机.以及各种各样的小零件,要将这些部件装配成一辆汽车,这个装配过

[原创]java WEB学习笔记12:一个简单的serlet连接数据库实验

本博客为原创:综合 尚硅谷(http://www.atguigu.com)的系统教程(深表感谢)和 网络上的现有资源(博客,文档,图书等),资源的出处我会标明 本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱好者,互联网技术发烧友 微博:伊直都在0221 QQ:951226918 ---------------------------------