【C++】数据类型与操作实践:详细解析与优化
文章目录
- 💯前言
- 💯题目一:三个数的倒序输出
- 1.1 题目描述与代码实现
- 代码实现:
- 1.2 代码解析与细节说明
- 1.3 使用 `int` 类型的合理性分析
- 1.4 其他数据类型的考虑
- 1.5 代码优化建议
- 💯题目二:数据类型的存储大小
- 2.1 题目描述与代码实现
- 代码实现:
- 2.2 代码解析与存储大小分析
- 2.3 变量未赋值的优化
- 2.4 使用字符 `' '` 还是字符串 `" "`
- 2.5 进一步优化代码
- 💯C++ 基础概念的拓展与总结
- 3.1 数据类型的选择
- 3.2 `sizeof` 运算符的深度应用
- 3.3 输入输出优化的高级思考
- 💯小结
💯前言
- 在编程学习的高级阶段中,理解和精通数据类型、输入输出机制的底层实现至关重要,尤其是在高效编程和复杂项目中,这些基础知识的掌握将极大地影响代码的质量和性能。本次我们对若干典型的 C++ 题目进行了深入分析,涉及了
int
、short
类型的内存占用与行为,以及多变量操作、反序输出等相关内容。本文旨在对代码编写、优化思路、内存管理等方面提供深入的讨论和讲解,以助力高层次程序设计的理解。
C++ 参考手册
💯题目一:三个数的倒序输出
- 倒序
1.1 题目描述与代码实现
在第一道题目中,我们需要输入三个整数 a a a、 b b b、 c c c,并以反序的形式输出。题目设定的整数范围如下:
- 0 ≤ a , b , c ≤ 2 31 − 1 0 \leq a, b, c \leq 2^{31} - 1 0≤a,b,c≤231−1
这意味着输入的整数可能达到非常大的数值,但仍然在有符号 32 位整数的表示范围内。因此,使用 int
类型是非常合适的,以下是基本的代码实现:
题目描述:
输入三个数,反序输出这三个数。
输入描述:
输入三个整数 a, b, c,以空格隔开, 0 ≤ a , b , c ≤ 2 31 − 1 0 \leq a, b, c \leq 2^{31} - 1 0≤a,b,c≤231−1
输出描述:
输出一行,三个整数,空格隔开,按反序输出。
示例:
输入:
2 6 9
输出:
9 6 2
代码实现:
#include <iostream>
using namespace std;int main() {int a, b, c; // 定义三个整型变量 a, b, ccin >> a >> b >> c; // 从标准输入读取三个整数cout << c << " " << b << " " << a << endl; // 以反序输出三个变量return 0;
}
1.2 代码解析与细节说明
-
输入部分:
使用cin
来读取输入的三个整数,用户可以通过空格或换行符分隔这些输入。 -
输出部分:
使用cout
以反序输出这三个整数,整数之间以空格分隔。
当我们输入 2 6 9
时,输出结果是 9 6 2
,这符合题目的要求,即按输入的反序进行输出。
1.3 使用 int
类型的合理性分析
题目中给定的整数范围上限为 2 31 − 1 2^{31} - 1 231−1,这恰好与 C++ 中的 int
类型的范围一致。具体分析如下:
-
int
类型的取值范围:现代编译器中,int
类型通常是一个 32 位的有符号整数,其取值范围为:− 2 31 到 2 31 − 1 -2^{31} { 到 } 2^{31}-1 −231到231−1,即 − 2 , 147 , 483 , 648 到 2 , 147 , 483 , 647 -2,147,483,648 { 到 } 2,147,483,647 −2,147,483,648到2,147,483,647
因此,题目所给的范围从 0 到 2 31 − 1 2^{31} - 1 231−1 完全位于
int
的范围内,因此选择int
类型是合理且高效的。
1.4 其他数据类型的考虑
unsigned int
:如果明确知道输入的数值总是非负的,那么可以选择unsigned int
,其取值范围为 0 , 2 32 − 1 0, 2^{32} - 1 0,232−1,可以进一步扩大数值上限。long long
:若需表示超过int
的取值范围(例如处理更大的整数),可以使用long long
类型。然而在本题中,使用long long
不仅不必要,还会增加内存占用及计算成本。
1.5 代码优化建议
尽管代码已较为简洁,但依然可以进一步优化:
- 使用
\n
替代endl
,因为endl
不仅进行换行,还会刷新输出缓冲区。在频繁的输出操作中,这种刷新可能导致性能的下降,而\n
仅执行换行操作。 - 若需要更健壮的输入处理,可以添加输入校验逻辑,以确保输入符合预期,例如防止非整型输入导致程序崩溃。不过在本题场景下,这类校验并非必需。
💯题目二:数据类型的存储大小
- 整型数据类型存储空间大小
2.1 题目描述与代码实现
第二道题目要求分别定义一个 int
类型和一个 short
类型的变量,并输出它们的存储大小(单位为字节)。实现这一需求可以利用 C++ 中的 sizeof
运算符。
题目描述:
定义两个变量,分别是 int
和 short
类型,输出它们的存储大小(单位:字节)。
输入描述:
无。
输出描述:
一行,两个整数,分别是两个变量的存储空间大小,用一个空格隔开。
示例:
输入:
无。
输出:
4 2
代码实现:
#include <iostream>
using namespace std;int main() {int a; // 定义 int 类型变量 ashort b; // 定义 short 类型变量 bcout << sizeof(a) << " " << sizeof(b) << endl; // 输出它们的存储大小return 0;
}
2.2 代码解析与存储大小分析
-
sizeof
运算符:sizeof
是一个关键字,用于获取变量或类型的存储大小,单位是字节。- 在代码中,
sizeof(a)
返回int
类型的大小,sizeof(b)
返回short
类型的大小。
-
存储大小的常见取值:
在大多数现代计算机系统中:int
通常为 4 字节(32 位),其取值范围为 − 2 31 , 2 31 − 1 -2^{31}, 2^{31}-1 −231,231−1。short
通常为 2 字节(16 位),其取值范围为 − 2 15 , 2 15 − 1 -2^{15}, 2^{15}-1 −215,215−1。
因此,通常的输出结果是
4 2
,但这也可能随编译器或系统架构的不同而有所变化,例如在某些特定的嵌入式系统中。
2.3 变量未赋值的优化
在上述代码中,我们定义了变量 a
和 b
,但并未赋初值。实际上,sizeof
只关心变量的类型而不是它的值,因此未赋值不会对结果产生影响。这种做法使代码更加简洁和高效。
例如:
#include <iostream>
using namespace std;int main() {int a; // 定义一个 int 类型变量 a(未赋值)short b; // 定义一个 short 类型变量 b(未赋值)cout << sizeof(a) << ' ' << sizeof(b) << endl; // 输出变量的存储大小return 0;
}
2.4 使用字符 ' '
还是字符串 " "
在输出两个变量大小时,使用空格作为分隔符可以选择字符 ' '
或字符串 " "
。
- 使用字符
' '
:- 更加节省内存,因为字符
' '
只占用 1 个字节。 - 更加直观且简洁,适合单字符分隔符的场景。
- 更加节省内存,因为字符
- 使用字符串
" "
:- 更加灵活,适合需要复杂分隔符或包含多个字符的情况,但相比字符占用更多的内存。
在本题的代码中,两者的效果完全相同,因此使用字符 ' '
显得更加高效和合理。
2.5 进一步优化代码
为了使代码更加清晰,我们可以直接在 sizeof
运算符中传递类型,而不需要定义变量。例如:
#include <iostream>
using namespace std;int main() {cout << sizeof(int) << ' ' << sizeof(short) << endl;return 0;
}
这样可以减少不必要的变量定义,使代码更加精炼,突出关注点在于类型的大小。
💯C++ 基础概念的拓展与总结
3.1 数据类型的选择
在程序设计中选择合适的数据类型是非常关键的,涉及内存的利用效率、程序的执行效率以及代码的可读性。
int
vsshort
:int
常用于一般的整数运算,其性能和数值范围在大多数场景中表现良好。short
更适合数值范围较小但需要节省内存的场景,尤其在嵌入式设备中使用广泛。
long long
:当处理比int
更大的数值(超过 32 位)时,long long
提供了 64 位的精度和数值范围。unsigned
修饰符:如果可以确定数值不会为负,那么unsigned
可以用来扩展数值的正值上限,适用于数组下标、计数器等场景。
在实际应用中,数据类型选择不仅影响代码的可读性和正确性,还会对程序的内存使用和性能产生深远影响。例如,在内存受限的场合(如嵌入式开发)中,合理选择较小的数据类型可以节约大量资源;而在涉及大量计算时,选择合适的类型则可以显著提升程序的运行速度。
3.2 sizeof
运算符的深度应用
sizeof
是 C/C++ 中非常重要的运算符,尤其在需要动态管理内存和跨平台编程时,sizeof
能帮助开发者更好地理解和管理内存。- 在复杂的数据结构如
struct
或class
中,使用sizeof
可以方便地确定结构体的内存布局和大小,从而对内存对齐、数据结构的设计做出优化。 sizeof
还可以用于检查编译环境中不同数据类型的大小,以确保程序具有良好的可移植性,避免因平台差异导致的内存溢出或数据丢失。
3.3 输入输出优化的高级思考
- 使用
\n
替代endl
:在 C++ 中,endl
既执行换行又刷新输出缓冲区,在频繁输出时可能显著降低性能。而\n
仅仅是换行符,不涉及缓冲区的刷新,因而性能更高。对于不需要立即看到输出的场景,优先选择\n
会提升整体效率。 - 选择合适的分隔符:在处理大量数据输出时,分隔符的选择直接影响到输出的可读性和性能。字符
' '
通常是最节省资源的选择,而复杂输出中使用字符串" "
则可以提高灵活性。
💯小结
-
本文深入探讨了 C++ 中数据类型的选择与优化,以及如何通过代码实践来掌握这些概念。通过对两个具体题目的详细分析,我们讨论了如何选择合适的数据类型,以及如何使用sizeof
运算符来获取类型的存储大小。此外,我们还提出了一些代码优化的建议,从而使代码更加简洁、性能更佳。 -
掌握数据类型的选择和优化,是编写高效、可维护代码的基础。在实际的软件开发中,数据类型的选择不仅影响程序的内存占用和运行效率,也对后续的可扩展性和可靠性产生重要影响。希望本文的内容能够帮助你在理解 C++ 的数据类型与代码优化方面迈上一个新的台阶。
-
在 C++ 的学习与实践过程中,掌握好每一个细节都是成为高级开发者的必经之路。每一个细微的优化和改进,都会在复杂的软件系统中累积成显著的性能提升。无论是选择适当的数据类型,还是精简代码的输入输出操作,这些都需要不断的实践与总结。希望各位读者能在 C++ 的学习之路上不断探索,逐步提升自己的编程能力,最终成为能够编写出高效、优雅代码的开发者。
相关文章:

【C++】数据类型与操作实践:详细解析与优化
博客主页: [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: C 文章目录 💯前言💯题目一:三个数的倒序输出1.1 题目描述与代码实现代码实现: 1.2 代码解析与细节说明1.3 使用 int 类型的合理性分析1.4 其他数据类型的考虑1.5 代码优…...

C# 集合(Collection)
文章目录 前言一、动态数组(ArrayList)二、哈希表(Hashtable)三、排序列表(SortedList)四、堆栈(Stack)五、队列(Queue)六、点阵列(BitArray&…...

【智能控制】实验,基于MATLAB的模糊推理系统设计,模糊控制系统设计
关注作者了解更多 我的其他CSDN专栏 过程控制系统 工程测试技术 虚拟仪器技术 可编程控制器 工业现场总线 数字图像处理 智能控制 传感器技术 嵌入式系统 复变函数与积分变换 单片机原理 线性代数 大学物理 热工与工程流体力学 数字信号处理 光电融合集成电路…...
前端跳转路由的时候,清掉缓存
清除路由缓存的方法 使用 $router.push() 方法:在跳转路由时,可以通过传递一个包含 replace: true 属性的对象来实现清除路由缓存。例如: this.$router.push({ path: "/new-route", replace: true }); 使用 $router.replace…...
基于 LlamaFactory 的 LoRA 微调模型支持 vllm 批量推理的实现
背景 LlamaFactory 的 LoRA 微调功能非常便捷,微调后的模型,没有直接支持 vllm 推理,故导致推理速度不够快。 LlamaFactory 目前支持通过 VLLM API 进行部署,调用 API 时的响应速度,仍然没有vllm批量推理的速度快。 …...

【赵渝强老师】PostgreSQL的物理存储结构
PostgreSQL在执行initdb的数据库集群初始化时会指定一个目录。该目录通过环境变量$PGDATA来表示。当数据库集群初始化完成后,会在这个目录生成相关的子目录以及一些文件。这些生成的文件就是PostgreSQL的物理存储结构中的文件。如下图所示。 如上图所示,…...

智能探针技术:实现可视、可知、可诊的主动网络运维策略
网络维护的重要性 网络运维是确保网络系统稳定、高效、安全运行的关键活动。在当今这个高度依赖信息技术的时代,网络运维的重要性不仅体现在技术层面,更关乎到企业运营的方方面面。网络运维具有保障网络的稳定性、提升网络运维性能、降低企业运营成本等…...
CTF-PWN: 全保护下格式化字符串利用 [第一届“吾杯”网络安全技能大赛 如果能重来] 赛后学习(不会)
通过网盘分享的文件:如果能重来.zip 链接: https://pan.baidu.com/s/1XKIJx32nWVcSpKiWFQGpYA?pwd1111 提取码: 1111 --来自百度网盘超级会员v2的分享漏洞分析 格式化字符串漏洞,在printf(format); __int64 sub_13D7() {char format[56]; // [rsp10h] [rbp-40h]…...

debian 11 虚拟机环境搭建过坑记录
目录 安装过程系统配置修改 sudoers 文件网络配置换源安装桌面mount nfs 挂载安装复制功能tab 无法补全其他安装 软件配置eclipse 配置git 配置老虚拟机硬盘挂载 参考 原来去 debian 官网下载了一个最新的 debian 12,安装后出现包依赖问题,搞了半天&…...
MYSQL 什么是内连接 外连接 左连接 右连接?及适用场景
在 SQL 中,连接(JOIN)是用于组合来自两个或更多表的行的一种方法。根据连接的方式不同,可以分为几种类型的连接:内连接(INNER JOIN)、外连接(OUTER JOIN)、左连接&#x…...

利用Ubuntu批量下载modis图像(New)
由于最近modis原来批量下载的代码不再直接给出,因此,再次梳理如何利用Ubuntu下载modis数据。 之前的下载代码为十分长,现在只给出一部分,需要自己再补充另一部分。之前的为: 感谢郭师兄的指导(https://blo…...

【Springboot】@Autowired和@Resource的区别
【Springboot】Autowired和Resource的区别 【一】定义【1】Autowired【2】Resource 【二】区别【1】包含的属性不同【2】Autowired默认按byType自动装配,而Resource默认byName自动装配【3】注解应用的地方不同【4】出处不同【5】装配顺序不用(1ÿ…...

UIE与ERNIE-Layout:智能视频问答任务初探
内容来自百度飞桨ai社区UIE与ERNIE-Layout:智能视频问答任务初探: 如有侵权,请联系删除 1 环境准备 In [2] # 安装依赖库 !pip install paddlenlp --upgrade !pip install paddleocr --upgrade !pip install paddlespeech --upgrade In …...

数据结构:树
树的基本定义: 树是一种数据结构,它是由n(n>1)个有限节点组成一个具有层次关系的集合。把它叫做 “树” 是因为它看起来像一棵倒挂的树,也就是说它是根朝上,而叶朝下的。它具有以下的特点: …...
docker 怎么启动nginx
在Docker中启动Nginx容器是一个简单的过程。以下是启动Nginx容器的步骤: 拉取Nginx镜像: 首先,你需要从Docker Hub拉取Nginx的官方镜像。使用以下命令: docker pull nginx运行Nginx容器: 使用docker run命令来启动一个…...

【智商检测——DP】
题目 代码 #include <bits/stdc.h> using namespace std; const int N 1e510, M 110; int f[N][M]; int main() {int n, k;cin >> n >> k;for(int i 1; i < n; i){int x;cin >> x;f[i][0] __gcd(f[i-1][0], x);for(int j 1; j < min(i, k)…...

YOLOv11改进,YOLOv11添加SAConv可切换空洞卷积,二次创新C3k2结构
摘要 作者提出的技术结合了递归特征金字塔和可切换空洞卷积,通过强化多尺度特征学习和自适应的空洞卷积,显著提升了目标检测的效果。 理论介绍 空洞卷积(Atrous Convolution)是一种可以在卷积操作中插入“空洞”来扩大感受野的技术,更有效地捕捉到图像中的大范围上下文…...

使用R语言优雅的获取任意区域的POI,道路,河流等数据
POI是“Polnt of Information”的缩写,中文可以翻译为“信息点”。是地图上任何非地理意义的有意义的点,如商店,酒吧,加油站,医院,车站等。POI,道路网,河流等是我们日常研究中经常需…...
【设计模式】工厂方法模式 在java中的应用
文章目录 1. 引言工厂方法模式的定义 2. 工厂方法模式的核心概念工厂方法模式的目的和原理与其他创建型模式的比较(如简单工厂和抽象工厂) 3. Java中工厂方法模式的实现基本的工厂方法模式结构示例代码:创建不同类型的日志记录器 4. 工厂方法…...

Pytest框架学习20--conftest.py
conftest.py作用 正常情况下,如果多个py文件之间需要共享数据,如一个变量,或者调用一个方法 需要先在一个新文件中编写函数等,然后在使用的文件中导入,然后使用 pytest中定义个conftest.py来实现数据,参…...
uniapp 对接腾讯云IM群组成员管理(增删改查)
UniApp 实战:腾讯云IM群组成员管理(增删改查) 一、前言 在社交类App开发中,群组成员管理是核心功能之一。本文将基于UniApp框架,结合腾讯云IM SDK,详细讲解如何实现群组成员的增删改查全流程。 权限校验…...
Cursor实现用excel数据填充word模版的方法
cursor主页:https://www.cursor.com/ 任务目标:把excel格式的数据里的单元格,按照某一个固定模版填充到word中 文章目录 注意事项逐步生成程序1. 确定格式2. 调试程序 注意事项 直接给一个excel文件和最终呈现的word文件的示例,…...
基于服务器使用 apt 安装、配置 Nginx
🧾 一、查看可安装的 Nginx 版本 首先,你可以运行以下命令查看可用版本: apt-cache madison nginx-core输出示例: nginx-core | 1.18.0-6ubuntu14.6 | http://archive.ubuntu.com/ubuntu focal-updates/main amd64 Packages ng…...
系统设计 --- MongoDB亿级数据查询优化策略
系统设计 --- MongoDB亿级数据查询分表策略 背景Solution --- 分表 背景 使用audit log实现Audi Trail功能 Audit Trail范围: 六个月数据量: 每秒5-7条audi log,共计7千万 – 1亿条数据需要实现全文检索按照时间倒序因为license问题,不能使用ELK只能使用…...

【CSS position 属性】static、relative、fixed、absolute 、sticky详细介绍,多层嵌套定位示例
文章目录 ★ position 的五种类型及基本用法 ★ 一、position 属性概述 二、position 的五种类型详解(初学者版) 1. static(默认值) 2. relative(相对定位) 3. absolute(绝对定位) 4. fixed(固定定位) 5. sticky(粘性定位) 三、定位元素的层级关系(z-i…...
土地利用/土地覆盖遥感解译与基于CLUE模型未来变化情景预测;从基础到高级,涵盖ArcGIS数据处理、ENVI遥感解译与CLUE模型情景模拟等
🔍 土地利用/土地覆盖数据是生态、环境和气象等诸多领域模型的关键输入参数。通过遥感影像解译技术,可以精准获取历史或当前任何一个区域的土地利用/土地覆盖情况。这些数据不仅能够用于评估区域生态环境的变化趋势,还能有效评价重大生态工程…...
智能AI电话机器人系统的识别能力现状与发展水平
一、引言 随着人工智能技术的飞速发展,AI电话机器人系统已经从简单的自动应答工具演变为具备复杂交互能力的智能助手。这类系统结合了语音识别、自然语言处理、情感计算和机器学习等多项前沿技术,在客户服务、营销推广、信息查询等领域发挥着越来越重要…...
LangChain知识库管理后端接口:数据库操作详解—— 构建本地知识库系统的基础《二》
这段 Python 代码是一个完整的 知识库数据库操作模块,用于对本地知识库系统中的知识库进行增删改查(CRUD)操作。它基于 SQLAlchemy ORM 框架 和一个自定义的装饰器 with_session 实现数据库会话管理。 📘 一、整体功能概述 该模块…...

基于IDIG-GAN的小样本电机轴承故障诊断
目录 🔍 核心问题 一、IDIG-GAN模型原理 1. 整体架构 2. 核心创新点 (1) 梯度归一化(Gradient Normalization) (2) 判别器梯度间隙正则化(Discriminator Gradient Gap Regularization) (3) 自注意力机制(Self-Attention) 3. 完整损失函数 二…...

uniapp 开发ios, xcode 提交app store connect 和 testflight内测
uniapp 中配置 配置manifest 文档:manifest.json 应用配置 | uni-app官网 hbuilderx中本地打包 下载IOS最新SDK 开发环境 | uni小程序SDK hbulderx 版本号:4.66 对应的sdk版本 4.66 两者必须一致 本地打包的资源导入到SDK 导入资源 | uni小程序SDK …...