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

news2024/11/25 10:33:08

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.coloradmin.cn/o/1827696.html

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

相关文章

C++访问Private,Protecd的一些方法总结

前言 在编写C程序中 我们偶尔会碰到这样的三种特殊修改变量值的需求&#xff1a; [1]在不修改类原本的实现下&#xff0c;访问修改类的Private变量 [2]在不修改类原本的实现下&#xff0c;修改类的Protected变量 Private变量访问 public类模版函数特化 这种办法利用了类模…

密码学-密码协议之零知识证明

一、前言 零知识证明实际上一种密码协议&#xff0c;该协议的一方称为证明者(Prover)&#xff0c;通常用P表示&#xff0c;协议的另一方是验证者(Verifier)&#xff0c;一般用V表示。零知识证明是指P试图使V相信某个论断是正确的&#xff0c;但却不向V提供任何有用的信息&…

springboot与flowable(7):流程变量

一、启动时添加流程变量 拿第一个流程图举例&#xff0c;创建一个新的流程定义。 Testvoid contextLoads() {DeploymentBuilder deployment repositoryService.createDeployment();deployment.addClasspathResource("process01/FirstFlow.bpmn20.xml");deployment.…

MFC工控项目实例之三theApp变量传递对话框参数

承接专栏《MFC工控项目实例之二主菜单制作》 用theApp变量传递对话框参数实时改变iPlotX坐标轴最小值、最大值。 1、新建IDD_SYS_DATA对话框&#xff0c;类名SYS_DATA。 三个编辑框IDC_EDIT1、IDC_EDIT2、IDC_EDIT3变量如图 2、SEAL_PRESSURE.h中添加代码 #include "re…

【单片机毕业设计选题24008】-基于单片机的寝室系统设计

系统功能: 1. 采用STM32最小系统板控制&#xff0c;将采集到温湿度光照等传感器数据显示在OLED上 2. 通过离线语音模块开关灯&#xff0c;风扇&#xff0c;门。 3. 监测到MQ2烟雾后触发报警。 4. 语音&手动&定时控制窗帘。 5. 按键开启布防模式&#xff0c;布防后…

java课设

项目简介:射击生存类小游戏 项目采用技术: 游戏引擎: Unity编程语言: Java图形处理: NVIDIA PhysX (物理引擎), HDRP (High Definition Render Pipeline)音效与音乐: FMOD, Wwise版本控制: Git 功能需求分析: 角色控制&#xff1a;玩家能够使用键盘和鼠标控制角色移动、瞄准…

【python基础实例】从文件命名中提取特定信息(数字、字母等)

【python基础实例】从文件命名中提取特定信息&#xff08;数字、字母等&#xff09; 在处理文件和数据时&#xff0c;我们经常需要从文件名中提取特定的信息&#xff0c;如日期、序号或项目标识符。Python提供了强大的字符串处理功能&#xff0c;可以轻松完成这些任务。本文将…

HttpOpenRequest 函数偶尔会引起崩溃的坑

通常我们会像下面一样调用&#xff1a; HINTERNET HttpOpenRequestA([in] HINTERNET hConnect,[in] LPCSTR lpszVerb,[in] LPCSTR lpszObjectName,[in] LPCSTR lpszVersion,[in] LPCSTR lpszReferrer,[in] LPCSTR *lplpszAcceptTypes,[in] DWORD dwFlags,[…

linux 部署瑞数6实战(维普,药监局)第一部分

声明 本文章中所有内容仅供学习交流使用&#xff0c;不用于其他任何目的&#xff0c;抓包内容、敏感网址、数据接口等均已做脱敏处理&#xff0c;严禁用于商业用途和非法用途&#xff0c;否则由此产生的一切后果均与作者无关&#xff01;wx 本文章未经许可禁止转载&…

1.22 LeetCode总结(基本算法)_位运算

进制的概念 进制即进位计数制&#xff0c;是利用固定的数字符号和统一的规则的带进位的计数方法。 任何一种进位计数制都有一个基数&#xff0c;基数为 X 的进位计数制称为 X 进制&#xff0c;表示每一个数位上的数运算时都是逢 X 进一。 504. 七进制数 手法1&#xff1a;当…

Qt自定义日志输出

Qt自定义日志输出 简略版&#xff1a; #include <QApplication> #include <QDebug> #include <QDateTime> #include <QFileInfo> // 将日志类型转换为字符串 QString typeToString(QtMsgType type) {switch (type) {case QtDebugMsg: return "D…

20240613日志:COPAL

Location: Beijing 1 大模型剪枝 Fig. 1.1大模型压缩-剪枝 剪枝的分类&#xff1a;结构化修剪对于简化大型语言模型和提高其效率尤其相关。非结构化修剪关注的是选择性地去除单个权重&#xff0c;旨在消除网络中不那么关键的连接。 修剪的基于阶段的分类&#xff1a;修剪可以在…

微软OneDrive简介:特点、应用场景、使用方法、注意事项

还是大剑师兰特&#xff1a;曾是美国某知名大学计算机专业研究生&#xff0c;现为航空航海领域高级前端工程师&#xff1b;CSDN知名博主&#xff0c;GIS领域优质创作者&#xff0c;深耕openlayers、leaflet、mapbox、cesium&#xff0c;canvas&#xff0c;webgl&#xff0c;ech…

热门开源项目ChatTTS: 国内语音技术突破,实现弯道超车

✨✨ 欢迎大家来访Srlua的博文&#xff08;づ&#xffe3;3&#xffe3;&#xff09;づ╭❤&#xff5e;✨✨ &#x1f31f;&#x1f31f; 欢迎各位亲爱的读者&#xff0c;感谢你们抽出宝贵的时间来阅读我的文章。 我是Srlua小谢&#xff0c;在这里我会分享我的知识和经验。&am…

Cesium入门学习(一)

下载cesium源代码 安装依赖 npm install注册账户&#xff0c;申请一个token 没有这个token&#xff0c;会导致地图中只能看到一个宇宙&#xff0c;没有办法看到地球 cesium的官网&#xff1a;cesium官网 替换token 替换对应位置的token 启动 运行 npm run build npm r…

西门子学习笔记15 - 位逻辑操作的学习

1、点动操作&#xff08;按下按钮就启动松开就停止&#xff09; 2、自锁电路&#xff08;可以自己保持的状态除非常闭停止按下&#xff09; 3、取反操作&#xff08;顾名思义就是反过来1就变成0&#xff0c;0就变成1&#xff09; 4、置为复位&#xff08;置位之后如果不复位的话…

注解(Annotation)(一)

Java 注解&#xff08; Annotation &#xff09;又称 Java 标注&#xff0c;是 JDK5.0 引入的一种注释机制。 Java 语言中的类、 构造器、 方法、成员变量、参数等都可以被注解进行标注。 自定义注解 --- 格式 自定义注解就是自己做一个注解来使用。 public interface …

Python自然语言处理的力量:NLTK库介绍

文章目录 Python自然语言处理的力量&#xff1a;NLTK库介绍1. NLP的魔法&#xff1a;为什么选择NLTK&#xff1f;2. 什么是NLTK&#xff1f;3. 快速安装NLTK4. 8个NLTK的基本函数使用方法4.1 分词4.2 词性标注4.3 命名实体识别4.4 频率分布4.5 停用词过滤4.6 词形还原4.7 句子分…

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…

cmake构建Qt项目

cmake构建Qt项目 项目结构 一、添加头文件 # 添加头文件目录&#xff0c;还需要在add_executable中添加头文件&#xff01;&#xff01;&#xff01; include_directories(${CMAKE_CURRENT_SOURCE_DIR}/include) add_executable(landlardsinclude/test.h)二、添加源文件 aux…