C++初学者指南第一步---4.基本类型

C++初学者指南第一步—4.基本类型

文章目录

  • C++初学者指南第一步---4.基本类型
    • 1.变量声明
    • 2.快速概览
      • Booleans 布尔型
      • Characters 字符型
      • Signed Integers 有符号整数
      • Unsigned Integers 无符号整数
      • Floating Point Types 浮点数类型
    • 3.Common Number Representations 常用的数字表示常用数字的表示方法
    • 4.Arithmetic Operations 算术运算
      • Increment/Decrement 递增/递减
    • 5.Comparisons 比较运算
      • 2-way Comparisons 二元比较
      • 3-Way Comparisons With <=> 三元比较用<=> C++20
    • 6.布尔型逻辑运算
      • 操作符
      • 转换为布尔型
      • 短路求值
    • 7.基础类型的内存大小
    • 8.std::numeric_limits<type> (数值范围模板类)
    • 9.Type Narrowing类型缩小(类型窄化)
    • 10.花括号初始化(统一初始化)C++11
    • 11.位运算
      • Bitwise Logic 按位逻辑运算
      • Bitwise Shifts 按位移位
    • 12.算术转换和提升

基本类型是所有复杂类型(如列表、哈希映射、树、图等)的基本构建块。

1.变量声明

变量声明的基本语法

type variable = value;
type variable {value};C++11
// 声明 & 初始化 'i':
int i = 1;
// 打印‘i’的值:
cout << i << '\n';  
int j {5};
cout << j << '\n';

在这里插入图片描述
注意:基本类型的变量默认不会被初始化!

int k;  // k不会被初始化!
cout << k << '\n';  // k可能是任何值

因为在c++中,你只需要为你使用的内存付出代价(大内存块的初始化可能相当昂贵)。
注意:但是: 在声明变量时,你几乎总是需要对其进行初始化,以防止出现bug!

2.快速概览

Booleans 布尔型

bool b1 = true;
bool b2 = false;

Characters 字符型

  • 最小整数;通常为1字节
  • 在x86/x86_64平台上,signed(有符合) 类型值的范围为[-128,127]。

Signed Integers 有符号整数

n bits ⇒ values ∈ [ − 2 n − 1 -2^{n-1} 2n1, 2 n − 1 2^{n-1} 2n1-1]
n位数 ⇒ 值属于 [ − 2 n − 1 -2^{n-1} 2n1 2 n − 1 2^{n-1} 2n1-1] 的范围

short s = 7;        
int   i = 12347;
long  l1 = -7856974990L;
long long  l2 = 89565656974990LL;
// ' C++14增加的数字分隔符,
long l3 = 512'232'697'499;

Unsigned Integers 无符号整数

n bits ⇒ values ∈ [0, 2 n − 1 2^{n-1} 2n1]
n位数 ⇒ 值属于 [0, 2 n − 1 2^{n-1} 2n1] 的范围

unsigned u1 = 12347U; 
unsigned long u2 = 123478912345UL;  
unsigned long long u3 = 123478912345ULL;  
// 非10进制
unsigned x = 0x4A;        // 16进制
unsigned b = 0b10110101;  // 二进制 C++14

Floating Point Types 浮点数类型

  • float 通常为IEEE 754格式32位。
  • double 通常为IEEE 754格式64位。
  • long double 在x86/x86-64上通常为80位。
float       f  = 1.88f;
double      d1 = 3.5e38;
long double d2 = 3.5e38L; C++11
// ' digit separator C++14
double d3 = 512'232'697'499.052;

3.Common Number Representations 常用的数字表示常用数字的表示方法

在这里插入图片描述
浮点数工具:值映射的交互式可视化工具

4.Arithmetic Operations 算术运算

  • 表达式 a ⊕ b 返回操作⊕应用于 a 和 b值的结果
  • 表达式 a ⊕= b 存储 a中操作⊕的结果
代码注释
int a = 4;
int b = 3;
变量a设置为值4
变量b设置为值3
a = a + b;
a += b;
a: 7 加法运算
a: 10
a = a - b;
a -= b;
a: 7 减法运算
a: 4
a = a * b;
a *= b;
a: 12 乘法运算
a: 36
a = a / b;
a /= b;
a: 12 除法运算
a: 4
a = a % b;a: 1 除法余数运算(取模)

Increment/Decrement 递增/递减

  • 将值更改为递增1/递减 1
  • 前缀表达式 ++x / --x 返回新的(递增/递减)值
  • 后缀表达式 x++ / x-- 增加/减少值,但返回旧值
代码注释
int a = 4;
int b = 3;
a: 4
b: 3
b = a++;
b = ++a;
a: 5 b: 4
a: 6 b: 6

5.Comparisons 比较运算

2-way Comparisons 二元比较

比较结果为 true 或 false

代码注释
int x = 10;
int y = 5;
bool b1 = (x == 5);
bool b2 = (x != 6);
false 相等比较
true 不相等比较
bool b3 = x > y;
bool b4 = x < y;
bool b5 = y >= 5;
bool b6 = x <= 30;
true 大于比较
false 小于比较
true 大于等于比较
true 小于等于比较

3-Way Comparisons With <=> 三元比较用<=> C++20

确定 2 个对象的相对顺序:
(a <=> b) < 0 如果 a < b
(a <=> b) > 0 如果 a > b
(a <=> b) == 0 如果 a 和 b 相等

  • 三元比较返回一个可与字面量 0 比较的比较类别值
  • 返回的值来自三种可能的类别之一:std::strong_ordering、std::weak_ordering 或 std::partial_ordering

4 <=> 6 → std::strong_ordering::less
5 <=> 5 → std::strong_ordering::equal
8 <=> 1 → std::strong_ordering::greater

6.布尔型逻辑运算

操作符

bool a = true;
bool b = false;
bool c = a && b;   // false    逻辑与 AND
bool d = a || b;   // true     逻辑或 OR
bool e = !a;       // false    逻辑非 NOT
// 备选的拼写:
bool x = a and b;  // false
bool y = a or b;   // true
bool z = not a;    // false

转换为布尔型

  • 0 始终为 false;
  • 其他一切都是true;
bool f = 12;   // true   (int → bool)
bool g = 0;    // false  (int → bool)
bool h = 1.2;  // true   (double → bool)

短路求值

如果出现以下情况,则不计算布尔比较的第二个操作数 在计算第一个操作数后,结果已经知道了。

int i = 2;  
int k = 8;
bool b1 = (i > 0) || (k < 3);

i > 0 已经是true ,k < 3不计算,因为逻辑或的结果已经是true。

7.基础类型的内存大小

所有类型大小都是 sizeof(char) 的倍数

cout << sizeof(char);   // 1
cout << sizeof(bool);   // 1
cout << sizeof(short);  // 2
cout << sizeof(int);    // 4
cout << sizeof(long);   // 8
// number of bits in a char
cout << CHAR_BIT;   // 8
char   c = 'A';
bool   b = true;
int    i = 1234;
long   l = 12;
short  s = 8;

在这里插入图片描述
大小取决于平台
C++仅提供基本保证

  • sizeof(short) ≥ sizeof(char)
  • sizeof(short) ≥ sizeof(char)
  • sizeof(int) ≥ sizeof(short)
  • sizeof(int) ≥ sizeof(short)
  • sizeof(long) ≥ sizeof(int)
  • sizeof(long) ≥ sizeof(int)

例如,在某些 32 位平台上: int = long

整数大小保证  C++11

#include <cstdint>
  • 精确尺寸(在某些平台上不可用)
    int8_t,   int16_t,   int32_t,   int64_t,   uint8_t, …
  • 保证最小尺寸
    int_least8_t,   uint_least8_t, …
  • 速度最快且保证最小尺寸
    int_fast8_t,   uint_fast8_t, …

固定宽度浮点类型保证  C++23

#include <stdfloat>// storage bits: sign + exponent + mantissa(存储位: 符号 + 指数 + 尾数)
std::float16_t  a = 12.3f16;   // 1 +  5  +  10 =  16 bits =  2 B
std::float32_t  b = 12.3f32;   // 1 +  8  +  23 =  32 bits =  4 B
std::float64_t  c = 12.3f64;   // 1 + 11  +  52 =  64 bits =  8 B
std::float128_t d = 12.3f128;  // 1 + 15  + 112 = 128 bits = 16 B
std::bfloat16_t e = 12.3b16;   // 1 +  8  +   7 =  16 bits =  2 B

8.std::numeric_limits (数值范围模板类)

#include <limits>
// smallest negative value:(double类型的最小负值)
cout << std::numeric_limits<double>::lowest();
// float/double: smallest value > 0 (float/double类型的最小正值)
// integers: smallest value
cout << std::numeric_limits<double>::min();
// largest positive value:(可以表示的最大正值)
cout << std::numeric_limits<double>::max();
// smallest difference btw. 1 and next value:(1和下一个值之间最小差值,用于浮点数比较)
cout << std::numeric_limits<double>::epsilon();

在这里插入图片描述
cppreference:数值限制

9.Type Narrowing类型缩小(类型窄化)

  • 从可以表示更多值的类型转换为可以表示更少值的类型
  • 可能会导致信息丢失
  • 一般来说,没有编译器警告——默默地发生
  • 隐藏的潜在运行时错误来源
double   d = 1.23456;
float    f = 2.53f;
unsigned u = 120u;
double e = f;  // OK  float → double
int i = 2.5;   // 缩小 double → int
int j = u;     // 缩小 unsigned int → int
int k = f;     // 缩小 float → int

10.花括号初始化(统一初始化)C++11

type variable { value };
  • 适用于所有基本类型
  • 缩小转换 ⇒ 编译器警告
double   d {1.23456};  // OK
float    f {2.53f};    // OK
unsigned u {120u};     // OK
double e {f};  // OK float → double
int i {2.5};   //  COMPILER WARNING: double       → int
int j {u};     //  COMPILER WARNING: unsigned int → int
int k {f};     //  COMPILER WARNING: float        → int

注意:确保防止静默类型转换,特别是将无符号整数转换缩小为有符号整数转换——它们会导致难以发现的运行时错误!

11.位运算

Bitwise Logic 按位逻辑运算

表达式说明
a & bAND按位与
a | bOR按位或
a ^ bXOR按位异或
~aNOT按位反(反码)
#include <cstdint>
std::uint8_t a = 6;  
std::uint8_t b = 0b00001011;
std::uint8_t c1 = (a & b);  // 2
std::uint8_t c2 = (a | b);  // 15
std::uint8_t c3 = (a ^ b);  // 13
std::uint8_t c4 = ~a;       // 249
std::uint8_t c5 = ~b;       // 244
// test if int is even/odd:
bool a_odd  = a & 1;
bool a_even = !(a & 1);
memory bits:
0000 0110
0000 1011
0000 0010
0000 1111
0000 1101
1111 1001
1111 0100
result:
0false
1true

Bitwise Shifts 按位移位

表达式说明
x << n返回 x 的值,其位向左移动 n 位
x >> n返回 x 的值,其位向右移动 n 位
x <<= n通过向左移动 n 位来修改 x
x >>= n通过向右移动 n 位来修改 x
#include <cstdint>
std::uint8_t a = 1;
a <<= 6;  // 64
a >>= 4;  // 4
std::uint8_t b1 = (1 << 1);  // 2
std::uint8_t b2 = (1 << 2);  // 4
std::uint8_t b3 = (1 << 4);  // 16
memory bits:
0000 0001
0100 0000
0000 0100
0000 0010
0000 0100
0001 0000

注意:把一个数据类型为N位的对象移动N位或更多位是未定义行为!

std::uint32_t i = 1;  // 32 bit type
i <<= 32;   未定义行为!
std::uint64_t j = 1;  // 64 bit type
j <<= 70;   未定义行为!

12.算术转换和提升

很遗憾,这里有一大堆规则(可以追溯到C语言)的目的是确定二元运算的两个操作数和结果的共同类型
Operand A ⊕ Operand B → Result

简单总结

涉及至少一种浮点类型的运算

  • long double ⊕ any other type → long double
  • double ⊕ float → double
  • double ⊕ any integer → double
  • float ⊕ any integer → float

两种整数类型的运算

  1. 先对两个操作数执行整数提升:基本上任何小于int的值都会被提升为int或unsigned int(取决于哪一种类型可以表示未提升类型的所有值)
  2. 如果两个操作数类型不同,则应用整数转换:
  • 两个有符号:较小类型转换为较大类型
  • 两个无符号:较小类型转换为较大类型
  • 有符号 ⊕ 无符号:
    1. 如果两者位宽相同,有符号转换为无符号
    2. 否则,如果无符号类型可以表示有符号类型的所有值,无符号转换为有符号
    3. 否则,两者都转换为无符号

附上原文链接
翻译和整理文章不易,如果文章对您有用请随手点个赞,谢谢!

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

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

相关文章

【数据结构】——常见排序

文章目录 一、 冒泡排序二、 选择排序三、插入排序四、 快速排序1. hoare版本2. 优化版本3. 前后指针法4. 非递归版本 五、 堆排序六、 希尔排序七、 归并排序1. 递归版本2. 非递归版本 八、 计数排序 在开始之前先准备一个交换数据的函数&#xff0c;排序会经常用到 //交换位置…

银河麒麟系统安装

新建虚拟机 选择典型下一步&#xff1a; 稍后安装操作系统 下一步 &#xff1a; 选择Linux Ubuntu 64位 下一步&#xff1a; 设置名称 选择一个虚拟机的位置进行下一步&#xff1a; 磁盘大小默认给20G 下一步&#xff1a; 点击完成 编辑虚拟机设置 点击CD/DVD(SATA) 使用IS…

Mysql数据库的锁机制

MySQL 中的锁可以按照粒度分为锁定整个表的表级锁&#xff08;table-level locking&#xff09;和锁定数据行的行级锁&#xff08;row-level locking&#xff09;表级锁开销小&#xff0c;加锁快&#xff0c;但是支持的并发度低&#xff0c;行级锁相反。 行锁 Innodb实现了以…

如何在小程序中实现页面之间的返回

在小程序中实现页面之间的返回&#xff0c;通常有以下几种方法&#xff0c;这些方法各有特点&#xff0c;适用于不同的场景&#xff1a; 1. 使用wx.navigateBack方法 描述&#xff1a;wx.navigateBack是微信小程序中用于关闭当前页面&#xff0c;返回上一页面或多级页面的API…

java技术专家面试指南80问【java学习+面试宝典】(九)

队列和栈是什么&#xff0c;列出它们的区别&#xff1f; 栈和队列两者都被用来预存储数据。java.util.Queue是一个接口&#xff0c;它的实现类在Java并发包中。队列允许先进先出&#xff08;FIFO&#xff09;检索元素&#xff0c;但并非总是这样。Deque接口允许从两端检索元素…

聊聊对Andorid的FileProvider的理解

最近在项目中遇到一个有关FileProvider的问题&#xff0c;由此来学习了一下FileProvider&#xff0c;有关笔记记录如下。 FileProvider是 Android 系统中一个特殊的内容提供者(ContentProvider), 它主要用于应用之间安全的共享文件。通过 FileProvider,应用可以生成一个 conte…

C#医院体检系统源码 PEIS源码 系统核心功能、特点、类型、设备对接-PACS放射科设备对接:DR、CT、MRI、钼靶。

C#医院体检系统源码 PEIS源码 系统核心功能、特点、类型、设备对接-PACS放射科设备对接:DR、CT、MRI、钼靶。 体检系统是为体检中心、医院体检科等体检机构专门开发的全流程管理系统。该系统通过软件实现检测仪器数据的自动提取&#xff0c;内置多级医生工作台&#xff0c;旨在…

每日一练:攻防世界:ewm

这道题我尝试了使用montagegaps解题&#xff0c;但是没有解出来&#xff0c;图片数量不是很多&#xff0c;可以尝试用PS直接拼图&#xff0c;但是这样学不到东西&#xff0c;我也就没尝试&#xff0c;直接看的官方WP 这段代码应该是改变工作目录到small&#xff0c;并且变量当…

基于springboot的宠物商城网站

文章目录 项目介绍主要功能截图:部分代码展示设计总结项目获取方式🍅 作者主页:超级无敌暴龙战士塔塔开 🍅 简介:Java领域优质创作者🏆、 简历模板、学习资料、面试题库【关注我,都给你】 🍅文末获取源码联系🍅 项目介绍 基于springboot的宠物商城网站,java项目…

软件复盘的目的及作用

一、软件复盘的目的 软件复盘是一种在软件开发完成后、通过整理软件开发工作中的经验和教训以及对软件缺陷、进度、质量等问题的反思&#xff0c;识别和总结出开发团队应该坚持和改进的软件开发过程和技术的工作方式。软件复盘的主要目的是&#xff1a; 识别和总结软件开发过…

【Ubuntu20.04】安装XRDP远程桌面服务

【Ubuntu20.04】安装XRDP远程桌面服务 安装xrdp sudo apt install xrdp sudo adduser xrdp ssl-cert sudo systemctl restart xrdp黑屏解决 修改startwm.sh文件 sudo gedit /etc/xrdp/startwm.sh在test -x /etc/X11/Xsession上一行添加 unset DBUS_SESSION_BUS_ADDRESS un…

Linux C编译器从零开发二

自定义分词器 test.c #include <ctype.h> #include <stdarg.h> #include <stdbool.h> #include <stdio.h> #include <stdlib.h> #include <string.h>typedef enum {TK_PUNCT, // PunctuatorsTK_NUM, // Numeric literalsTK_EOF, // …

基于carsim的线控转向仿真(1)--carsim车辆模型目标角度跟踪

一、Rwa转向执行总成建模 Rwa包括齿轮齿条机构、转向组件以及转向执行电机&#xff1b;如下图&#xff0c;电机输出轴通过齿轮减速增扭后&#xff0c;再经过一个半径为rp的小齿轮&#xff0c;直接带动齿条左右移动。齿条的移动通过转向摇臂&#xff0c;带动车轮转动&#xff0c…

使用 Apache SkyWalking 进行 Spring Cloud 应用的分布式追踪与监控:完整教程

使用 Apache SkyWalking 进行 Spring Cloud 应用的分布式追踪与监控&#xff1a;完整教程 SkyWalking 是一款开源的分布式追踪、性能监控和诊断平台&#xff0c;适用于微服务、云原生和容器化应用。它能够在分布式系统中收集和分析各个服务之间的调用关系和性能数据&#xff0…

PySide(PyQt)实现鼠标画框局部放大

按住鼠标左键画框&#xff0c;裁切画面并局部放大&#xff0c;可以用来生成ROI 1、在QtDesigner中创建ui文件&#xff0c;命名为crop.ui&#xff1a; 2、自定义脚本ImageLabel.py &#xff1a; from PySide6.QtCore import Qt, QRect, Signal, QPoint from PySide6.QtGui impo…

Redis高并发高可用

1. 复制机制 在分布式系统中&#xff0c;为了解决单点问题&#xff0c;通常会将数据复制多个副本部署到其他机器&#xff0c;以满足故障恢复和负载均衡等需求。Redis提供了复制功能&#xff0c;实现了相同数据的多个Redis副本。复制功能是高可用Redis的基础&#xff0c;后面的…

Unity 6预览版即将增加对visionOS 2的支持

Unity表示&#xff0c;届时将能帮助你创建更为身临其境的体验&#xff0c;并通过以下主要功能实现更大的视觉多样性&#xff1a; 支持混合形状&#xff0c;以实现更广泛的几何应用&#xff0c;包括变形和平滑&#xff0c;自然的动画。 立体渲染目标&#xff0c;帮助用户实现广…

长亭网络通信基础

长亭笔试之前就已经学过一遍了 这算温故而知新吧 TCP/IP 首先我在这里默写一下之前的7层和4层 应用层 应 【表示层 数据格式转换 传 【会话层 …

Vue 3 的常用响应式 API 总结

在vue3.x版本中&#xff0c;setup函数就是vue3 组合式API的入口&#xff0c;换句话说就是在setup中的写的代码&#xff0c;就是组合式API 的写法。下面总结常用的与响应式相关的api, 帮助您在 Vue 3 中创建响应式应用程序。 reactive() 和 ref()&#xff1a; 创建响应式对象和…

课设--学生成绩管理系统(一)

欢迎来到 Papicatch的博客 文章目录 &#x1f349;技术核心 &#x1f349;引言 &#x1f348;标识 &#x1f348;背景 &#x1f348;项目概述 &#x1f348; 文档概述 &#x1f349;可行性分析的前提 &#x1f348;项目的要求 &#x1f348;项目的目标 &#x1f348;…