C++学习笔记

C++

  • 1、函数重载
  • 2、类
    • 2.1、类的方法和属性
    • 2.2、类的方法的定义
    • 2.3、构造器和析构器
    • 2.4、基类与子类
    • 2.5、类的public、protected、private继承
    • 2.6、类的方法的重载
    • 2.7、子类方法的覆盖

1、函数重载

函数重载大概可以理解为,定义两个名字一模一样,但形参不一样的函数。通过传入参数可以判别具体执行哪一个函数。并且在这两个函数中,理论上可以执行截然不同的程序。
以下是一个简单的demo。

/* 
函数重载小实验——写一段代码求两个数或者三个数的平均值 
2023.9.7 
*/
#include <iostream>using namespace std;float average(float ,float ,float); 
float average(float ,float);float average(float a,float b,float c)
{;return (a+b+c)/3;
}float average(float a,float b)
{return (a+b)/2;
}int main()
{int choice;float temp1,temp2,temp3;float result;cout<<"please choose two or three numbers"<<endl;cin >> choice;if (choice == 2){cout<<"please enter two numbers:"<<endl;cin >> temp1 >> temp2;  result = average(temp1,temp2);}else if(choice == 3){cout<<"please enter three numbers:"<<endl;cin >> temp1 >> temp2 >> temp3;result = average(temp1,temp2,temp3);	}else {cout<<"your input is wrong!"<<endl;} cout<<"please result is:"<<result<<endl;return 0;
}

注:cin可以通过enter或tab来分割输入。

2、类

2.1、类的方法和属性

通过class定义一个叫car的类。类里面的变量就叫做属性,函数就叫做方法。

class car
{
public:int num;void run();		
};

2.2、类的方法的定义

在2.1中,我们声明了类中的有一个叫run的方法,但是具体到run函数里面到底在执行什么,还得再次定义一下。

void car::run(void)
{cout<<"running!"<<endl;
}

2.3、构造器和析构器

Ⅰ、类的构造器是指,在实例化这个类之后,程序会先执行一个和类同名的方法。
Ⅱ、类的析构器是指,当类被被使用完毕之后,程序会自动执行一个名字为“类名字前加个~”的方法。
但如果像2.1那样,没有定义构造器和析构器,那程序其实也会去执行构造器和析构器里面的程序的,只是此时的程序为空。
注:实例化是将一个类变成一个实体,一个类可以被无限次实例化。

#include <iostream>using namespace std;class car
{
public:int num;car(int);   //构造器可以传输参数~car(void);  //析构器不可以传输参数void run();		
};//构造器
car::car(int temp)
{num = temp;cout<<"this car's license number is:"<<num<<endl;
}//析构器,本代码是在main函数执行结束后才调用析构器方法的。
car::~car(void)
{cout<<"end."<<endl;
}void car::run(void)
{cout<<num<<" is running!"<<endl;
}int main()
{class car mycar(666);    //构造器的参数在实例化的时候就得赋上了class car yourcar(888); //再次实例化一个类对象mycar.run();yourcar.run();return 0;
}

2.4、基类与子类

基类又称父类,也就说我们可以再定义一个类,继承父类的变量和方法。

#include <iostream>using namespace std;//父类 
class car
{
public:int num;void run();		
};//子类 
class motorcycle:public car
{
public:void hand_brake();
};//父类的run方法 
void car::run(void)
{cout<<"running"<<endl;
}//子类的hand_brake方法 
void motorcycle::hand_brake(void)
{cout<<"notice! I'am using the hand brake!"<<endl;
}int main()
{class motorcycle my_motor;my_motor.run();my_motor.hand_brake();return 0;
}

2.5、类的public、protected、private继承

public:可以被任何实体访问,也可以被子类访问,以及类的函数成员访问。

protected:不能被类的实体访问,但可以被子类访问,也可以类的函数成员访问。
private:不能被类的实体访问,不可以被子类访问,但可以被类的函数成员访问。

#include <iostream>
using namespace std;//父类 
class car
{
public:int num;void run();	
protected:int test1;	
private:int test2;
};//子类 
class motorcycle:public car
{
public:void hand_brake();
};//父类的run方法 
void car::run(void)
{test1 = 1;   //✔ protected可以被类的函数成员访问test2 = 2;   //✔ private可以被类的函数成员访问cout<<"running"<<endl;
}//子类的hand_brake方法 
void motorcycle::hand_brake(void)
{test1 = 1;   //✔ protected可以被子类的函数成员访问//test2 = 2;  × private不可以被子类的函数成员访问cout<<"notice! I'am using the hand brake!"<<endl;
}int main()
{class motorcycle my_motor;my_motor.run();my_motor.num = 888;    //✔ public可以被实体访问//my_motor.test1 = 1;     × protected不可以被实体访问//my_motor.test2 = 2;     × private不可以被实体访问my_motor.hand_brake();return 0;
}

2.6、类的方法的重载

这里其实和第1章中的函数重载是一样的,只不过是类中定义两个名字一样的方法而已。

class car
{
public:void run();void run(int);	//定义两个同名的方法,一个有整形形参,一个没有。
};void car::run(void)
{cout<<"running"<<endl;
}void car::run(int temp)
{cout<<"speed running"<<endl;
}

2.7、子类方法的覆盖

子类再次声明一个和父类一模一样的方法,用以覆盖父类的方法。但值得注意的是,这里说的覆盖并不完全准确。当我们对父类进行实列化之后,再次调用run方法,执行依旧的父类中的run方法,而不是覆盖之后子类的run。这点从子类的函数成员可以调用父类的run方法也可以看出来。通过以下两段代码希望可以加强各位的理解。
代码一:

//父类
class car
{
public:void run();
};//子类 
class motorcycle:public car
{
public:void run();
};//父类的run方法 
void car::run(void)
{cout<<"running"<<endl;
}//子类的run方法。
void motorcycle::run(void)
{car::run();         //子类的函数成员可以直接调用子类的方法cout<<"the motorcycle is running"<<endl;
}

代码二:

#include <iostream>using namespace std;//父类
class car
{
public:void run();
};//子类 
class motorcycle:public car
{
public:void run();
};//父类的run方法 
void car::run(void)
{cout<<"the car is running"<<endl;
}//子类的run方法
void motorcycle::run(void)
{cout<<"the motorcycle is running"<<endl;
}int main()
{class car my_car;class motorcycle my_motor;my_car.run();   //调用的是父类的run方法my_motor.run();  //调用的是子类的run方法return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/71616.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

STM32F103ZE单片机呼吸灯源代码

//这个是中断文件/* USER CODE BEGIN Header *//********************************************************************************* file stm32f1xx_it.c* brief Interrupt Service Routines.**********************************************************************…

LabVIEW对EAST长脉冲等离子体运行的陀螺稳态运行控制

LabVIEW对EAST长脉冲等离子体运行的陀螺稳态运行控制 托卡马克是实现磁约束核聚变最有希望的解决方案之一。电子回旋共振加热&#xff08;ECRH是一种对托卡马克有吸引力的等离子体加热方法&#xff0c;具有耦合效率高&#xff0c;功率沉积定位好等优点。陀螺加速器是ECRH系统中…

JAVA设计模式第十讲:SPI - 业务差异解决方案

JAVA设计模式第十讲&#xff1a;SPI - 业务差异解决方案 我们需要在不修改源代码的情况下&#xff0c;动态为程序提供一系列额外的特性。首先想到的是Spring的AOP技术来构建应用插件&#xff0c;但是在Java自带的插件中&#xff0c;就有完整的实现。SPI&#xff08;Service Pro…

Win7旗舰版64位桌面创建32位IE方法

很多Win7 64位旗舰版用户系统桌面上的IE8浏览器&#xff0c;打开后都是64位的&#xff0c;而很多网站并不兼容64位的IE浏览器&#xff0c;其实在Win764位系统中IE是分为64位和32位的&#xff0c;出现这样的情况可能是桌面上的IE图标指响的是64位的IE&#xff0c;我们只要重新添…

grid弹性布局 设置宽高一致

效果图如下&#xff1a; 例子&#xff1a;设置每行四列的弹性布局&#xff0c;每个盒子宽高相同&#xff0c;间距为10px .left_list{display: grid;grid-gap: 10px 10px;grid-template-columns: repeat(4,1fr);.list_item{height: 0;padding-bottom:100%;/*高度设置为0&#…

io和进程day03(文件IO、文件属性函数、目录相关函数)

今日任务 代码 #include <stdio.h> #include <string.h> #include <stdlib.h> #include <sys/types.h> #include <sys/stat.h> #include <unistd.h> #include <sys/types.h> #include <pwd.h> #include <dirent.h> #in…

【图文并茂】C++介绍之串

1.1串 引子—— ​ 字符串简称为串&#xff0c;串是由字符元素构成的&#xff0c;其中元素的逻辑关系也是一种线性关系。串的处理在计算机非数值处理中占用重要的地位&#xff0c;如信息检索系统&#xff0c;文字编辑等都是以串数据作为处理对象 串是由零个或多个字符组成的…

得心应手应对 OOM 的疑难杂症

Java全能学习面试指南&#xff1a;https://www.javaxiaobear.cn/ 前面我们提到&#xff0c;类的初始化发生在类加载阶段&#xff0c;那对象都有哪些创建方式呢&#xff1f;除了我们常用的 new&#xff0c;还有下面这些方式&#xff1a; 使用 Class 的 newInstance 方法。使用…

[Vue3 博物馆管理系统] 使用Vue3、Element-plus的Layout 布局构建组图文章

系列文章目录 第一章 定制上中下&#xff08;顶部菜单、底部区域、中间主区域显示&#xff09;三层结构首页 第二章 使用Vue3、Element-plus菜单组件构建菜单 第三章 使用Vue3、Element-plus走马灯组件构建轮播图 第四章 使用Vue3、Element-plus tabs组件构建选项卡功能 第五章…

PHP反序列化漏洞

一、序列化&#xff0c;反序列化 序列化&#xff1a;将php对象压缩并按照一定格式转换成字符串过程反序列化&#xff1a;从字符串转换回php对象的过程目的&#xff1a;为了方便php对象的传输和存储 seriallize() 传入参数为php对象&#xff0c;序列化成字符串 unseriali…

go gin gorm连接postgres postgis输出geojson

go gin gorm连接postgres postgis输出geojson 1. 技术环境 go-gin-gorm postgres-postgis go vscode环境安装-智能提示配置 2. 简单实现代码 思路就是&#xff1a;采用原生sql实现查询、更新等&#xff0c;采用gorm的raw来执行sql语句 package mainimport ("fmt"&q…

nginx解决静态页面中ajax跨域方案配置

nginx 配置内容 &#xff1a; server { listen 9999;#监听端口 server_name localhost;#域名 add_header Access-Control-Allow-Origin *; # 允许跨域 #charset koi8-r; #access_log logs/host.access.log main; location / { …

python面向对象的一个简单实例

#发文福利# #!/usr/bin/env python # -*- coding:utf-8 -*-students {id001: {name: serena, age: 18, address: beijing},id002: {name: fanbingbing, age: 42, address: anhui},id003: {name: kahn, age: 20, address: shanghai}}class Student:def __init__(self, xid, na…

采访 Footprint Analytics CEO Navy:AI 与 Web3 的融合之道

Web3 正在引领互联网的下一个时代。然而&#xff0c;链上数据碎片化、不标准化的问题依然存在。Footprint Analytics 推出一站式数据解决方案&#xff0c;通过 AI 技术实现区块链数据的自动收集、清洗、关联&#xff0c;构建跨链数据标准&#xff0c;让开发者更便捷地访问和分析…

JavaScript 之 Symbol 数据类型

一、简介 ​ symbol类型是ES6新引入的一种基本数据类型&#xff0c;该类型具有静态属性和静态方法。其中静态属性暴露了几个内建的成员对象&#xff0c;静态方法暴露了全局的symbol注册。 ​ symbol类型具有以下特点&#xff1a;① 唯一性&#xff1a;每个symbol值都是唯一的…

JavaScript设计模式(四)——策略模式、代理模式、观察者模式

个人简介 &#x1f440;个人主页&#xff1a; 前端杂货铺 &#x1f64b;‍♂️学习方向&#xff1a; 主攻前端方向&#xff0c;正逐渐往全干发展 &#x1f4c3;个人状态&#xff1a; 研发工程师&#xff0c;现效力于中国工业软件事业 &#x1f680;人生格言&#xff1a; 积跬步…

【MySQL基础】事务隔离03

目录 隔离性与隔离级别事务隔离的实现事务的启动方式MySQL事务代码示例 在MySQL中&#xff0c;事务支持是在引擎层实现的。MySQL是一个支持多引擎的系统&#xff0c;但并不是所有的引擎都支持事务。比如 MySQL 原生的 MyISAM 引擎就不支持事务&#xff0c;这也是 MyISAM 被 Inn…

uniapp的两个跳转方式

uniapp内置多种跳转方式&#xff0c;我这里介绍两个最常用的跳转&#xff0c;uni.navigateTo和uni.switchTab&#xff0c;前者为跳转到非TabBar页面&#xff0c;后者为跳转到TabBar页面&#xff0c;所谓TabBar就是底部导航栏配置的页面&#xff0c;例如下方的index.vue。 在pa…

29 | 聊聊性能测试的基本方法与应用领域

并发用户数、响应时间、系统吞吐量之间的关系 当系统并发用户数较少时&#xff0c;系统的吞吐量也低&#xff0c;系统处于空闲状态&#xff0c;这个阶段被称为 “空闲区间”。 并发用户数进一步增长&#xff0c;系统的处理能力逐渐趋于饱和&#xff0c;因此每个用户的响应时间会…

Java 日志技术

所以说&#xff0c;要学Logback&#xff01; 配置文件 Logback提供了一个核心配置文件logback.xml&#xff0c;日志框架在记录日志时会读取配置文件中的配置信息&#xff0c;从而记录日志的形式。 可以配置日志输出的位置是文件还是控制台可以配置日志输出的格式还可以配置日…