2021-4-20 日记 C++(九)

本文介绍了C++中面向对象的基本概念,包括类的定义、成员的访问控制、构造函数及析构函数的作用。通过实例说明如何创建类和对象,以及如何通过对象访问类的成员。

C++是一门面向对象的语言,而抽象性则是面向对象方法的基本特征。我们将具有相同属性和行为的一组对象抽象为类。

根据对象的属性,我们把具有相同属性的对象归为一个类。而相同的,我们也可以根据类定义一个具有类属性的对象。

面向对象方法的另一个重要特征是封装,它意味着对象的属性和服务会被结合成一个独立的系统单位,并且对象的内部细节会被尽可能的隐蔽。打个比方,手机就是一个封装对象,手机上的按键就是它与外界的接口。我们可以通过这个接口完成很多操作,但具体操作是如何进行的,操作有多么复杂我们都不关心,这些事情是制造商才需要关心的问题。

同样的,我们要尽可能的让别人能方便的用我们写的类完成各种操作,至于类里面是什么东西,使用者不需要了解。

光说这么多干巴巴的其实也没什么人会记得住,也没必要去记住,先看看类是如何定义的:

class 类名{
	public:
		公有数据成员或公有函数的定义;
	protected:
		保护数据成员或保护函数的定义;
	private:
		私有数据成员或私有函数的定义;
};
class Lei1{
	public:
		Lei1();
		~Lei1();
		addcount();
	private:
		int count;
};

乍一看好像信息量很大,其实不然,我们慢慢讲。

首先定义类的关键字是class,至于类名叫啥你喜欢。而里面的public和private是啥意思呢?是对于数据成员和函数成员的等级分类,那么啥是等级分类呢?

比如说你的个人信息,名字、性别是public的,代表这两项信息是公开的,是大伙都能知道的。而身份证号码、体重、年龄这三项消息则是private的,代表这些是私有的,是不对外公开的。如果说有个人想知道你的名字和性别,那TA直接获得TA想知道的。那如果TA想知道你的体重呢?不好意思,这不方便透露。

那怎么样才能知道你的体重呢?就要通过你本人,或者说经过你本人的同意,别人才能获得你体重的数据。类就像是你这个人,而你(类)的信息是有等级划分的,如果有人想知道你(类)的信息,那么他就要向你(类)申请。而每个人想知道的信息都可能不一样,所以你会根据不同的人回答不同的东西。那么问你的人就被当做是一个“对象”。

我们刚才写的这几行代码里面,可以留意到private里面有一个叫count的变量,这意味着这个变量是私有的,那如果我们非要访问这个私有的数据呢?那首先我们需要先建立一个接口,也就是定义一个对象来对类进行操作。

定义对象的格式如下:

类名 对象名;
Lei1 L1;

这样,我们就建立了一个叫L1的对象,而这个叫L1的对象是Lei1这个类的对象。那接下来如何对类进行操作呢?格式如下:

对象名.属性;
对象名.成员函数名(实参1,实参2...);

我们这时候发现,在对类进行操作的时候不需要加类名了,这是因为我们的对象其实已经“绑定”了一个类,当建立了L1这个对象之后,L1它就已经代表是类Lei1了。所以在进行操作的时候,没有必要再加入类名了。

那我们想访问count这个属性,可以直接写L1.count吗?答案是否定的。因为count是一个私有数据成员,它不可以被对象直接访问。但是它可以被类的成员间接访问,我们可以通过一个函数调用count,然后再通过对象调用这个调用count的函数达到访问count的目的。

关于成员的存取控制的更多详细内容,比如protected级之类的内容,大家可以在其他更专业的地方了解,这里不做更多详述。

类与对象能代码尽可能的被封装起来,就比如我们之前写的简单计算器,如果换做是用类实现,代码能够更加简洁,甚至能够做到在主函数里面只有建立对象、对象调用函数两行代码,就完成我们整个计算器的启动和结束。至于类里面的复杂逻辑,则由我们去实现了。

接下来讲讲什么是构造函数析构函数。说白了,构造函数就是对象的初始化,而析构函数则是对象使用结束后进行内存释放操作的函数。

比如说我们的count变量,我们不定义它的初值,但我们可以通过构造函数,在每个对象建立的同时为对象的数据成员进行初始化。需要注意的是,构造函数的函数名跟类名必须一致,并且不需要有返回类型。

例如:`

Lei1(int i)
{
	count=i;
}

我们这样定义Lei1的构造函数,代表我们在建立对象时可以同时为count初始化。

Lei1 L1(5);
Lei1 L2(10);

这样,L1对象的count初值就为5,而L2对象的count初值就为10。

至于析构函数,只有用到动态内存的时候才会用得上,我们暂时不讲。今天大概就说这么多,明天我们会开始着手做一个新的项目,大概花两天日记的时间完成这个用类实现的项目。另外大家可以尝试一下把简单计算器做成类的形式,其实原理很简单的。

该数据集通过合成方式模拟了多种发动机在运行过程中的传感器监测数据,旨在构建一个用于机械系统故障检测的基准资源,特别适用于汽车领域的诊断分析。数据按固定时间间隔采集,涵盖了发动机性能指标、异常状态以及工作模式等多维度信息。 时间戳:数据类型为日期时间,记录了每个数据点的采集时刻。序列起始于2024年12月24日10:00,并以5分钟为间隔持续生成,体现了对发动机运行状态的连续监测。 温度(摄氏度):以浮点数形式记录发动机的温度读数。其数值范围通常处于60至120摄氏度之间,反映了发动机在常规工况下的典型温度区间。 转速(转/分钟):以浮点数表示发动机曲轴的旋转速度。该参数在1000至4000转/分钟的范围内随机生成,符合多数发动机在正常运转时的转速特征。 燃油效率(公里/升):浮点型变量,用于衡量发动机的燃料利用效能,即每升燃料所能支持的行驶里程。其取值范围设定在15至30公里/升之间。 振动_X、振动_Y、振动_Z:这三个浮点数列分别记录了发动机在三维空间坐标系中各轴向的振动强度。测量值标准化至0到1的标度,较高的数值通常暗示存在异常振动,可能与潜在的机械故障相关。 扭矩(牛·米):以浮点数表征发动机输出的旋转力矩,数值区间为50至200牛·米,体现了发动机的负载能力。 功率输出(千瓦):浮点型变量,描述发动机单位时间内做功的速率,取值范围为20至100千瓦。 故障状态:整型分类变量,用于标识发动机的异常程度,共分为四个等级:0代表正常状态,1表示轻微故障,2对应中等故障,3指示严重故障。该列作为分类任务的目标变量,支持基于传感器数据预测故障等级。 运行模式:字符串类型变量,描述发动机当前的工作状态,主要包括:怠速(发动机运转但无负载)、巡航(发动机在常规负载下平稳运行)、重载(发动机承受高负荷或高压工况)。 数据集整体包含1000条记录,每条记录对应特定时刻的发动机性能快照。其中故障状态涵盖从正常到严重故障的四级分类,有助于训练模型实现故障预测与诊断。所有数据均为合成生成,旨在模拟真实的发动机性能变化与典型故障场景,所包含的温度、转速、燃油效率、振动、扭矩及功率输出等关键传感指标,均为影响发动机故障判定的重要因素。 资源来源于网络分享,仅用于学习交流使用,请勿用于商业,如有侵权请联系我删除!
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值