C++ 基础进阶

news2025/4/18 4:11:58

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>
  • 结构体
    1. 构造函数:与结构体名称保持一致的函数,注意:构造函数没有返回值
    2. 结构体函数:结构体中的普通函数,可以通过 . 进行调用。
    3. 运算符重载operator 运算符
  • const 在函数中的作用const 可以修饰整个函数,可以只修饰函数的参数,可以只修饰函数体。
  • 扩展:字符串与数字之间的转换。

一、 函数重载

可以用一个函数名构造多个函数,各个同名函数之间参数一定不同。要满足以下规则任意一条:

  1. 函数的参数类型不同。
  2. 函数的个数不同。
  3. 函数的参数不同。

注意:仅有函数的返回值不同不能进行函数重载!

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. 结构体函数只能供结构体实例调用,调用方式为:实例.结构体函数(参数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;	// 输出applebanana
	
    return 0;
}

const 在函数中的作用

  1. const 修饰整个函数:表示返回值是一个常量,这样使用几乎无意义。

    const int add(int x, int y){
    	return x + y;
    }
    
  2. 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 指针本身不能被修改。
    
  3. 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:字符串与数字之间的转换

  1. 任意数字类型转换为字符串:to_string()

    int a = 10;
    double b = 3.14;
    
    
    string a_s = to_string(a);
    string b_s = to_string(b);
    
  2. 字符串转换为数字类型:

    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);
    
  3. 提取字符串中的字符转换为整型:

    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:开辟空间的方法

  1. 使用malloc()free() 函数,注意要导入头文件<stdlib.h>

    int* i_ptr = (int*)malloc(sizeof(int) * 10);	// 要进行强制类型转换
    free(i_ptr);									// 一定要释放开辟的内存空间
    
  2. 使用newdelete 方法

    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;
    

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

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

相关文章

【OS】Process Management(3)

《计算机操作系统&#xff08;第三版&#xff09;》&#xff08;汤小丹&#xff09;学习笔记 文章目录 5、进程通信&#xff08;Inter-Process Communication&#xff09;5.1、进程通信的类型5.1.1、共享存储器系统&#xff08;Shared Memory System&#xff09;5.1.2、消息传递…

单reactor实战

前言&#xff1a;reactor作为一种高性能的范式&#xff0c;值得我们学习 本次目标 实现一个基于的reactor 具备echo功能的服务器 核心组件 Reactor本身是靠一个事件驱动的框架,无疑引出一个类似于moduo的"EventLoop "以及boost.asio中的context而言&#xff0c;不断…

初阶C++笔记第一篇:C++基础语法

虽然以下大多数知识点都在C语言中学过&#xff0c;但还是有一些知识点和C语言不同&#xff0c;比如&#xff1a;代码格式、头文件、关键字、输入输出、字符串类型等... 1. 初识C 1.1 第一个C程序 编写C分为4个步骤&#xff1a; 创建项目创建文件编写代码运行程序 C的第一条…

无需libpacp库,BPF指令高效捕获指定数据包

【环境】无libpacp库的Linux服务器 【要求】高效率读取数据包&#xff0c;并过滤指定端口和ip 目前遇到两个问题 一是手写BPF&#xff0c;难以兼容&#xff0c;有些无法正常过滤二是性能消耗问题&#xff0c;尽可能控制到1% 大方向&#xff1a;过滤数据包要在内核层处理&…

react实现上传图片到阿里云OSS以及问题解决(保姆级)

一、优势 提高上传速度&#xff1a;前端直传利用了浏览器与 OSS 之间的直接连接&#xff0c;能够充分利用用户的网络带宽。相比之下&#xff0c;后端传递文件时&#xff0c;文件需要经过后端服务器的中转&#xff0c;可能会受到后端服务器网络环境和处理能力的限制&#xff0c;…

Python 字典和集合(常见的映射方法)

本章内容的大纲如下&#xff1a; 常见的字典方法 如何处理查找不到的键 标准库中 dict 类型的变种set 和 frozenset 类型 散列表的工作原理 散列表带来的潜在影响&#xff08;什么样的数据类型可作为键、不可预知的 顺序&#xff0c;等等&#xff09; 常见的映射方法 映射类型…

Matlab轴承故障信号仿真与故障分析

1.摘要 本文介绍了一个基于Matlab的轴承故障信号仿真与分析程序&#xff0c;旨在模拟和分析轴承内圈故障信号的特征。程序首先通过生成故障信号、共振信号和调制信号&#xff0c;添加噪声和离散化处理&#xff0c;构建模拟的振动信号&#xff0c;并保存相关数据。通过快速傅里…

Linux 进程 | 概念 / 特征 / 状态 / 优先级 / 空间

注&#xff1a; 本文为 “Linux 进程” 相关文章合辑。 未整理去重。 Linux 进程概念&#xff08;精讲&#xff09; A little strawberry 于 2021-10-15 10:23:55 发布 基本概念 课本概念&#xff1a;程序的一个执行实例&#xff0c;正在执行的程序等。 内核观点&#xff…

重回全面发展亲自操刀

项目场景&#xff1a; 今年工作变动&#xff0c;优化后在一家做国有项目的私人公司安顿下来了。公司环境不如以前&#xff0c;但是好在瑞欣依然可以每天方便的买到。人文氛围挺好&#xff0c;就是工时感觉有点紧&#xff0c;可能长期从事产品迭代开发&#xff0c;一下子转变做项…

3D珠宝渲染用什么软件比较好?渲染100邀请码1a12

印度珠宝商 Mohar Fine Jewels 和英国宝石商 Gemfields 在今年推出了合作珠宝系列——「Emeralds in Full Bloom」&#xff0c;它的灵感源自花草绽放的春季田野&#xff0c;共有 39 件作品&#xff0c;下面这个以植物为主题的开口手镯就是其中一件。 在数字时代&#xff0c;像这…

【数据结构】邻接矩阵完全指南:原理、实现与稠密图优化技巧​

邻接矩阵 导读一、图的存储结构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问题与解决总结 源码框架取自江协科技&#xff0c;在此基础上做扩展开发。 任务1 本文主要介绍利用stm32f103C8T6实现电位器控制PWM的占空比…

Uniapp 集成极光推送(JPush)完整指南

文章目录 前言一、准备工作1. 注册极光开发者账号2. 创建应用3. Uniapp项目准备 二、集成极光推送插件方法一&#xff1a;使用UniPush&#xff08;推荐&#xff09;方法二&#xff1a;手动集成极光推送SDK 三、配置原生平台参数四、核心功能实现1. 获取RegistrationID2. 设置别…

2025年常见渗透测试面试题-sql(题目+回答)

网络安全领域各种资源&#xff0c;学习文档&#xff0c;以及工具分享、前沿信息分享、POC、EXP分享。不定期分享各种好玩的项目及好用的工具&#xff0c;欢迎关注。 目录 SQLi 一、发现test.jsp?cid150 注入点的5种WebShell获取思路 1. 文件写入攻击 2. 日志文件劫持 3.…

【RabbitMQ】队列模型

1.概述 RabbitMQ作为消息队列&#xff0c;有6种队列模型&#xff0c;分别在不同的场景进行使用&#xff0c;分别是Hello World&#xff0c;Work queues&#xff0c;Publish/Subscribe&#xff0c;Routing&#xff0c;Topics&#xff0c;RPC。 下面就分别对几个模型进行讲述。…

StarRocks 助力首汽约车精细化运营

作者&#xff1a;任智红&#xff0c;首汽约车大数据负责人 更多交流&#xff0c;联系我们&#xff1a;https://wx.focussend.com/weComLink/mobileQrCodeLink/334%201%202/ffbe5 导读&#xff1a; 本文整理自首汽约车大数据负责人任智红在 StarRocks 年度峰会上的演讲&#xf…

痉挛性斜颈康复助力:饮食调养指南

痉挛性斜颈患者除了积极治疗&#xff0c;合理饮食也能辅助缓解症状&#xff0c;提升生活质量。其健康饮食可从以下方面着手&#xff1a; 高蛋白质食物助力肌肉修复 痉挛性斜颈会导致颈部肌肉异常收缩&#xff0c;消耗较多能量&#xff0c;蛋白质有助于肌肉的修复与维持。日常可…

mysql镜像创建docker容器,及其可能遇到的问题

前提&#xff0c;已经弄好基本的docker服务了。 一、基本流程 1、目录准备 我自己的资料喜欢放在 /data 目录下&#xff0c;所以老规矩&#xff1a; 先进入 /data 目录&#xff1a; cd /data 创建 mysql 目录并进入&#xff1a; mkdir mysql cd mysql 2、镜像查找 docke…

JavaEE——线程的状态

目录 前言1. NEW2. TERMINATED3. RUNNABLE4. 三种阻塞状态总结 前言 本篇文章来讲解线程的几种状态。在Java中&#xff0c;线程的状态是一个枚举类型&#xff0c;Thread.State。其中一共分为了六个状态。分别为&#xff1a;NEW,RUNNABLE,BLOCKED,WAITING,TIMED_WAITING, TERMI…

RuntimeError: Error(s) in loading state_dict for ChartParser

一 bug错误 最近使用千问大模型有一个bug&#xff0c;报错信息如下 raise RuntimeError(Error(s) in loading state_dict for {}:\n\t{}.format( RuntimeError: Error(s) in loading state_dict for ChartParser:Unexpected key(s) in state_dict: "pretrained_model.em…