C++ 基础进阶
C++ 基础进阶
内容概述:
- 函数重载:
int add(int x, inty);,long long add(long long x, long long y);,double add(double x, double y); - 模板函数:
template<typename T>或template<class T> - 结构体:
- 构造函数:与结构体名称保持一致的函数,注意:构造函数没有返回值。
- 结构体函数:结构体中的普通函数,可以通过
.进行调用。 - 运算符重载:
operator 运算符。
- const 在函数中的作用:
const可以修饰整个函数,可以只修饰函数的参数,可以只修饰函数体。 - 扩展:字符串与数字之间的转换。
一、 函数重载
可以用一个函数名构造多个函数,各个同名函数之间参数一定不同。要满足以下规则任意一条:
- 函数的参数类型不同。
- 函数的个数不同。
- 函数的参数不同。
注意:仅有函数的返回值不同不能进行函数重载!
int add(int x, int y){return x + y;
}long long add(long long x, long long y){return x + y;
}double add(double x, double y){return x + y;
}
二、模板函数
声明模板参数的方式:template<typename T> 或 template<class T>,其中 T 是人为设定的,可以用任何标识符表示。
模板参数的意义:可以使用模板参数来表示任意的数据类型的参数。
使用模板参数可以定义模板函数,即将参数的类型都设置为 T 或 将返回值类型设置为 T。
模板函数
// 定义模板函数
template<typename T>
T add(T x, T y){return x + y;
}// 调用模板函数
add(1, 2); // 隐式调用,可以自动推算出变量类型add<double>(1.14, 2.37); // 显示调用,指定参数类型为 double
三、结构体
1. 构造函数
在结构体中直接定义一个与结构体同名的函数,要求这个函数没有返回值。
构造函数一旦结构体被实例化就直接被调用。
// 定义
struct Node{char name[10];int length;// 不带参数的构造函数Node(){this->length = 0; // 直接将实例化的结构体中 len 初始化为0;也可以直接使用:len = 0;this->name[0] = '\0'; // 修正:应该将第一个字符设为结束符cout<<"空空如也"<<endl;}// 带参数的构造函数Node(const char* name_t, int len){ // 因为传入的是一个字符串常量,但是这里的参数是一个指针,是不安全的,因此要加const进行修饰int i = 0;while(i < len && len < 9){name[i] = name_t[i];i++;}length = len; // 修正:删除了多余的字符name[length] = '\0';cout<<"我的名字是:"<<name<<endl;}
};// 调用方式一(推荐):
Node n; // 输出 “空空如也”
Node m("kongkong", 8); // 输出 “我的名字是:kongkong”,注意如果是输入“空空”的话会出现问题,中文UTF-8实际上会占用多个字节。// 调用方式二:
Node n = Node(); // 输出 “空空如也”
Node m = Node("kongkong", 8) // 输出 “我的名字是:kongkong”
2. 结构体函数
向定义普通函数一样在结构体中定义函数
结构体函数与普通函数的区别:
- 结构体函数能够直接访问结构体实例中的变量。
- 结构体函数只能供结构体实例调用,调用方式为:
实例.结构体函数(参数1, 参数2, ...)
// 定义
struct Node{string fruit;void print(){printf("我是 %s 水果", fruit.c_str());}
};int main(){Node f;f.fruit = "apple";f.print();return 0;
}
3. 运算符重载
运算符重载通常用在结构体中,用于处理相同类型的结构体之间的运算关系
方法:operator 运算符
struct Node{string fruit;Node(string a){fruit = a;}// 重载运算符为string operator+ (const Node &other){return this->fruit + other.fruit;}
};int main(){Node f("apple");Node l("banana");cout<<(f + l)<<endl; // 输出applebananareturn 0;
}
const 在函数中的作用
-
const修饰整个函数:表示返回值是一个常量,这样使用几乎无意义。const int add(int x, int y){return x + y; } -
const修饰函数的参数:表示参数是要给常量,值不可修改。int add(const int x, int y){...} // x 不可以在函数进行修改 int add(const int* ptr, int y){...} // ptr 指针所指向的值是一个常量,不可修改 int add(int* const ptr, int y){...} // prt 指针本身不能被修改。 -
conste修饰函数体:常用在结构体中,修饰函数体会将结构体中的所有变量都修改为const类型的,相当于ptr*转变为了const ptr *。struct Node{string name;bool change(string new_name) const {this->name = new_name; // 这是错误的,结构体中的name已经变成了常量类型的。} };
四、综合代码:
// 结构体的各种操作
#include<iostream>
#include<stdlib.h>
using namespace std;
/*目标:给出一个整数序列,要求:1. 自动求出这个序列的奇数的个数与偶数的个数, 如果没有给出序列则直接进行简单的初始化。 2. 选择性的求出奇数数字或偶数数字的总和, 3. 重载加号运算符,要求两个结构体相加即为长度相加,并进行返回。4. 设置一个函数,要求根据输入(可能是整数类型或浮点数类型的数据)与长度进行相加,表示该数的特征值,并且返回该值。
*/const int MAXSIZE = 1000;
struct Nums{int nums[MAXSIZE];int length; // 序列长度 int odd_number, even_number; // 奇数个数,偶数个数 // 自动求出奇数个数与偶数个数(构造函数不能有返回值!!!)Nums(){this->odd_number = 0;this->even_number = 0; // 赋初值为 0;length = 0; // 不使用this也表示结构体中的变量。return ;}Nums(int *o_nums, int o_len){this->odd_number = 0;this->even_number = 0; // 赋初值为 0;length = o_len;for(int i = 0;i < o_len;i ++){if(o_nums[i] % 2 == 0){this->even_number ++;}else this->odd_number++;nums[i] = o_nums[i];}}// 计算奇数元素的总和 int to_sum_odd() const {int i = 0, odd_sum = 0;while(i < length){if(nums[i] % 2 != 0) odd_sum += nums[i];++ i;}return odd_sum;} // 计算偶数元素的总和 int to_sum_even() const {int i = 0, even_sum = 0;while(i < length){if(nums[i] % 2 == 0) even_sum += nums[i];++ i;}return even_sum;}template<typename T>T to_add_feature(const T other) const {return other + length;}// 重载运算符int operator+(const Nums& other) const {return this->length + other.length;} // 遍历输出这个序列 void traverse(){for(int i = 0;i < length;i ++){cout<<nums[i]<<' ';}cout<<endl;}
};
int main(){// 这里使用开辟内存的方式来表示数组,当然可以使用 temp[maxsize] 来表示数组
// int *temp = new int[12]{1, 2 ,3 ,4 ,5, 6, 7, 8, 9, 10, 11, 12};// 遍历赋值
// int *temp = new int[12];
// for(int i = 0;i < 12;i ++) temp[i] = i * (i + 1) + 1;// 也可以使用malloc开辟空间 int* temp = (int*)malloc(sizeof(int) * 5);for(int i = 0;i < 12;i ++) temp[i] = i * (i + 1) + 1;Nums n(temp, 12); // 也可以使用 Nums n = Nums(temp, 125); 推荐使用Nums n = (temp, 12); 来初始化结构体。 // 得到奇数之和 cout<<"奇数之和:"<<n.to_sum_odd()<<endl; // 得到偶数之和cout<<"偶数之和:"<<n.to_sum_even()<<endl;// 分别计算得到5 与 3.14的特征值cout<<"5 的特征值为:"<<n.to_add_feature(5)<<endl;cout<<"3.14 的特征值为:"<<n.to_add_feature(3.14)<<endl;// 定义第二个结构体int* t_arr = new int [5]{1, 2, 3, 4, 5};Nums m(t_arr, 5);cout<<"m + n = "<<m + n<<endl;// 遍历输出序列 cout<<"遍历输出序列: "<<endl;n.traverse();m.traverse();// 释放空间
// delete temp;delete t_arr;free(temp);return 0;
}
扩展1:字符串与数字之间的转换
-
任意数字类型转换为字符串:
to_string();int a = 10; double b = 3.14;string a_s = to_string(a); string b_s = to_string(b); -
字符串转换为数字类型:
string s1 = "30"; string s2 = "3.14";// 转换为 int类型 int s_i = stoi(s1);// 转换为 long long类型 int s_l = stoi(s1);// 转换为 float 类型 int s_f = stoi(s2);// 转换为 double 类型 int s_d = stoi(s2); -
提取字符串中的字符转换为整型:
string s = "1+2";// 方式一: int a1 = s[0] - '0'; int a2 = s[2] - '0';// 方式二:substr 用于提取字串,substr(起始位置,提取长度) int b1 = stoi(s.substr(0, 1)); int b2 = stoi(s.substr(2, 1));
扩展2:开辟空间的方法
-
使用
malloc()和free()函数,注意要导入头文件<stdlib.h>int* i_ptr = (int*)malloc(sizeof(int) * 10); // 要进行强制类型转换 free(i_ptr); // 一定要释放开辟的内存空间 -
使用
new和delete方法int* i_ptr = new int; // 也可以加括号, new(int); delete i_ptr; // 也可以添加括号, delete(i_ptr);// 指向一篇连续空间 int* j_ptr = new int[10]{1, 2 ,3 ,4, 5}; // 直接进行初始化 delete[] j_ptr; // 删除连续空间需要加[]char* k_ptr = new char[8]{}; delete[] k_ptr;
相关文章:
C++ 基础进阶
C 基础进阶 内容概述: 函数重载:int add(int x, inty);,long long add(long long x, long long y);,double add(double x, double y);模板函数:template<typename T> 或 template<class T>结构体&#x…...
【OS】Process Management(3)
《计算机操作系统(第三版)》(汤小丹)学习笔记 文章目录 5、进程通信(Inter-Process Communication)5.1、进程通信的类型5.1.1、共享存储器系统(Shared Memory System)5.1.2、消息传递…...
单reactor实战
前言:reactor作为一种高性能的范式,值得我们学习 本次目标 实现一个基于的reactor 具备echo功能的服务器 核心组件 Reactor本身是靠一个事件驱动的框架,无疑引出一个类似于moduo的"EventLoop "以及boost.asio中的context而言,不断…...
初阶C++笔记第一篇:C++基础语法
虽然以下大多数知识点都在C语言中学过,但还是有一些知识点和C语言不同,比如:代码格式、头文件、关键字、输入输出、字符串类型等... 1. 初识C 1.1 第一个C程序 编写C分为4个步骤: 创建项目创建文件编写代码运行程序 C的第一条…...
java基础 流(Stream)
Stream Stream 的核心概念核心特点 Stream 的操作分类中间操作(Intermediate Operations)终止操作(Terminal Operations) Stream 的流分类顺序流(Sequential Stream)并行流(Parallel Stream&…...
【AI】prompt engineering
prompt engineering ## prompt engineering ## prompt engineering ## prompt engineering 一、定义 Prompt 工程(Prompt Engineering)是指在使用语言模型(如 ChatGPT、文心一言等)等人工智能工具时,设计和优化输入提…...
无需libpacp库,BPF指令高效捕获指定数据包
【环境】无libpacp库的Linux服务器 【要求】高效率读取数据包,并过滤指定端口和ip 目前遇到两个问题 一是手写BPF,难以兼容,有些无法正常过滤二是性能消耗问题,尽可能控制到1% 大方向:过滤数据包要在内核层处理&…...
LeetCode算法题(Go语言实现)_36
题目 给定一个二叉树的根节点 root ,和一个整数 targetSum ,求该二叉树里节点值之和等于 targetSum 的 路径 的数目。 路径 不需要从根节点开始,也不需要在叶子节点结束,但是路径方向必须是向下的(只能从父节点到子节点…...
react实现上传图片到阿里云OSS以及问题解决(保姆级)
一、优势 提高上传速度:前端直传利用了浏览器与 OSS 之间的直接连接,能够充分利用用户的网络带宽。相比之下,后端传递文件时,文件需要经过后端服务器的中转,可能会受到后端服务器网络环境和处理能力的限制,…...
无法看到新安装的 JDK 17
在 Linux 系统中使用 update-alternatives --config java 无法看到新安装的 JDK 17,可能是由于 JDK 未正确注册到系统备选列表中。 一、原因分析 JDK 未注册到 update-alternatives update-alternatives 工具需要手动注册 JDK 路径后才能识别新版本。如果仅安装 JDK…...
LeetCode 3396.使数组元素互不相同所需的最少操作次数:O(n)一次倒序遍历
【LetMeFly】3396.使数组元素互不相同所需的最少操作次数:O(n)一次倒序遍历 力扣题目链接:https://leetcode.cn/problems/minimum-number-of-operations-to-make-elements-in-array-distinct/ 给你一个整数数组 nums,你需要确保数组中的元素…...
Vue2 快速过度 Vue3 教程 (后端学习)
隔好长一段时间没有写文章了,因为最近公司一个项目进度很赶,导致一直加班,没有时间空出来学习新的东西,这次趁着周末,赶紧补一下之前落下的一直想重新学一下整个大前端生态的想法,这次写一篇自己学习Vue3的…...
供应链管理-职业规划:数字化供应链管理专家 / 供应链管理商业模式专家 / 供应链管理方案专家
一、背景阐述 依据联合国产业分类标准,工业体系被细致划分为41个工业大类、207个工业中类以及666个工业小类。中国凭借其独特的产业布局,成为全球唯一一个全面涵盖所有这些门类的国家,成功构建起独立且完备的现代工业体系。这一辉煌成就&…...
无状态版的DHCPv6是不是SLAAC? 笔记250405
无状态版的DHCPv6是不是SLAAC? 笔记250405 无状态版 DHCPv6 不是 SLAAC,但二者在 IPv6 网络中可协同工作。以下是核心区别与协作关系: 本质区别 特性SLAAC无状态 DHCPv6主要功能生成 IPv6 地址(基于路由器通告的前缀)分发 DNS、…...
遍历算法及其应用详解
李升伟 整理 什么是遍历? 遍历是指按照某种规则或顺序,系统地访问数据结构(如树、图等)中的每个节点一次且仅一次的过程。遍历是算法设计中的基本操作,用于访问、检查或修改数据结构中的所有元素。 主要遍历算法 1…...
Python 字典和集合(常见的映射方法)
本章内容的大纲如下: 常见的字典方法 如何处理查找不到的键 标准库中 dict 类型的变种set 和 frozenset 类型 散列表的工作原理 散列表带来的潜在影响(什么样的数据类型可作为键、不可预知的 顺序,等等) 常见的映射方法 映射类型…...
基于大模型的ALS预测与手术优化系统技术方案
目录 技术方案文档:基于大模型的ALS预测与手术优化系统1. 数据预处理与特征工程模块流程图伪代码2. 多模态融合预测模型模型架构图伪代码3. 术中实时监测与动态干预系统系统流程图伪代码4. 统计验证与可解释性模块验证流程图伪代码示例(SHAP分析)5. 健康教育与交互系统系统架…...
创建一个简单的HTML游戏站
创建一个简单的HTML游戏站涉及多个步骤,包括规划网站结构、设计用户界面、编写游戏逻辑以及测试和部署。下面是一个详细的步骤指南: 1. 规划网站结构 确定目标受众:了解你的目标用户群体。选择游戏类型:决定你要开发的游戏类型&…...
Matlab轴承故障信号仿真与故障分析
1.摘要 本文介绍了一个基于Matlab的轴承故障信号仿真与分析程序,旨在模拟和分析轴承内圈故障信号的特征。程序首先通过生成故障信号、共振信号和调制信号,添加噪声和离散化处理,构建模拟的振动信号,并保存相关数据。通过快速傅里…...
Linux 进程 | 概念 / 特征 / 状态 / 优先级 / 空间
注: 本文为 “Linux 进程” 相关文章合辑。 未整理去重。 Linux 进程概念(精讲) A little strawberry 于 2021-10-15 10:23:55 发布 基本概念 课本概念:程序的一个执行实例,正在执行的程序等。 内核观点ÿ…...
项目中如何防止超卖
什么是超卖?假如只剩下一个库存,却被多个订单买到了,简单理解就是库存不够了还能正常下单。 方案1:数据库行级锁 1. 实体类 Data TableName("product") public class Product {TableId(type IdType.AUTO)private Lon…...
重回全面发展亲自操刀
项目场景: 今年工作变动,优化后在一家做国有项目的私人公司安顿下来了。公司环境不如以前,但是好在瑞欣依然可以每天方便的买到。人文氛围挺好,就是工时感觉有点紧,可能长期从事产品迭代开发,一下子转变做项…...
3D珠宝渲染用什么软件比较好?渲染100邀请码1a12
印度珠宝商 Mohar Fine Jewels 和英国宝石商 Gemfields 在今年推出了合作珠宝系列——「Emeralds in Full Bloom」,它的灵感源自花草绽放的春季田野,共有 39 件作品,下面这个以植物为主题的开口手镯就是其中一件。 在数字时代,像这…...
【数据结构】邻接矩阵完全指南:原理、实现与稠密图优化技巧
邻接矩阵 导读一、图的存储结构1.1 分类 二、邻接矩阵法2.1 邻接矩阵2.2 邻接矩阵存储网 三、邻接矩阵的存储结构四、算法评价4.1 时间复杂度4.2 空间复杂度 五、邻接矩阵的特点5.1 特点1解析5.2 特点2解析5.3 特点3解析5.4 特点4解析5.5 特点5解析5.6 特点6解析 结语 导读 大…...
【嵌入式-stm32电位器控制以及旋转编码器控制LED亮暗】
嵌入式-stm32电位器控制LED亮暗 任务1代码1Key.cKey.hTimer.cTimer.hPWM.cPWM.hmain.c 实验现象1任务2代码2Key.cKey.hmain.c 实验现象2问题与解决总结 源码框架取自江协科技,在此基础上做扩展开发。 任务1 本文主要介绍利用stm32f103C8T6实现电位器控制PWM的占空比…...
ragflow开启https访问:添加证书后,使用浏览器还是有警告,如何解决?
如果在 Windows 系统中安装了 PEM 证书(使用方法一通过证书管理器 MMC 导入),但浏览器仍然提示安全警告,可能有以下几个原因及解决方法: 1. 证书未正确安装到受信任的存储位置 问题:如果证书被导入到错误的存储位置(如“个人”而非“受信任的根证书颁发机构”),浏览器…...
字符串——面试考察高频算法题
目录 转换成小写字母 字符串转化为整数 反转相关的问题 反转字符串 k个一组反转 仅仅反转字母 反转字符串里的单词 验证回文串 判断是否互为字符重排 最长公共前缀 字符串压缩问题 转换成小写字母 给你一个字符串 s ,将该字符串中的大写字母转换成相同的…...
Uniapp 集成极光推送(JPush)完整指南
文章目录 前言一、准备工作1. 注册极光开发者账号2. 创建应用3. Uniapp项目准备 二、集成极光推送插件方法一:使用UniPush(推荐)方法二:手动集成极光推送SDK 三、配置原生平台参数四、核心功能实现1. 获取RegistrationID2. 设置别…...
Plusar集群搭建-Ubuntu20.04-Winterm
1 背景 已经部署了Pulsar集群在生产上,新项目需要用到Pulsar。对Pulsar不熟,故搭建练手。 环境:Windows10vmwareUbuntu20.04,ssh工具使用的Winterm。 使用的是root账户,ubuntu防火墙都ufw disable了。 2 参考文档 集…...
selenium元素获取
from selenium import webdriver from selenium.webdriver.common.by import Bydriver webdriver.Chrome()driver.maximize_window()#最大化窗口 #隐式等待 driver.implicitly_wait(10)#打开网页 driver.get("https://www.zhipin.com/beijing/?kacity-sites-101010100&q…...
