【Rust】数据类型

目录

 思维导图

1. 数据类型概述

1.1 标量类型

1.1.1 整数类型

1.1.2 浮点数类型

1.1.3 布尔类型

1.1.4 字符类型

1.2 复合类型

1.2.1 元组类型

1.2.2 数组类型

2. 类型注解与类型推断

3. 整数溢出处理

4. 数字运算

5. 示例


思维导图

1. 数据类型概述

Rust是一种静态类型语言,所有变量的类型在编译时必须明确。Rust支持两种主要的数据类型:标量类型和复合类型。

1.1 标量类型

标量类型表示单一值,Rust的四种主要标量类型包括:

  • 整数(Integer)
  • 浮点数(Floating-point)
  • 布尔值(Boolean)
  • 字符(Character)
1.1.1 整数类型
  • 整数类型是没有小数部分的数字,Rust提供了多种整数类型,包括有符号和无符号的8位、16位、32位、64位和128位整数。
  • 例如,u32表示一个无符号32位整数,范围从0到4294967295。
  • 整数的类型可以通过在数字后添加后缀来指定,如57u8表示8位无符号整数。
  • isize 和 usize 类型取决于程序运行的计算机架构,表格中用“arch”表示:如果是在 64 位架构上,则为 64 位;如果是在 32 位架构上,则为 32 位。
整数类型
LengthSignedUnsigned
8-biti8u8
16-biti16u16
32-biti32u32
64-biti64u64
128-biti128u128
archisizeusize

Rust特殊的编写字面量:

整数字面量
Number literalsExample
Decimal98_222
Hex0xff
Octal0o77
Binary0b1111_0000
Byte (u8 Only)b'A'
1.1.2 浮点数类型
  • Rust有两种浮点数类型:f32f64,分别表示32位和64位的浮点数。
  • 默认情况下,Rust使用f64,因为它在现代CPU上与f32的速度相近,但精度更高。
1.1.3 布尔类型
  • 布尔类型只有两个值:truefalse,在Rust中用bool表示。
1.1.4 字符类型
  • Rust的字符类型用char表示,支持Unicode标量值,可以表示多种语言的字符和符号。
  • 字符使用单引号表示,如'z''?'

1.2 复合类型

复合类型可以将多个值组合成一个类型,Rust的两种基本复合类型是元组(Tuple)和数组(Array)。

1.2.1 元组类型
  • 元组是将多个不同类型的值组合在一起的固定长度的集合。
  • 创建元组的语法为使用括号包裹的逗号分隔的值,例如let tup: (i32, f64, u8) = (500, 6.4, 1);
  • 元组的元素可以通过模式匹配进行解构。
1.2.2 数组类型
  • 数组是一种固定长度的集合,所有元素必须是同一类型。
  • 数组的定义方式为使用方括号包裹的逗号分隔的值,例如let a = [1, 2, 3, 4, 5];
  • 数组的类型可以通过指定元素类型和长度来定义,如let a: [i32; 5] = [1, 2, 3, 4, 5];
  • 数组的元素可以通过索引访问,例如let first = a[0];
  • 如果尝试访问超出数组范围的索引,Rust会在运行时崩溃并提示错误。

2. 类型注解与类型推断

Rust的编译器通常能够根据变量的值和使用方式推断出类型,但在某些情况下,例如从字符串转换为数字时,需要显式添加类型注解。示例代码如下:

let guess: u32 = "42".parse().expect("Not a number!");[14]

如果未提供类型注解,编译器会提示需要更多信息。

3. 整数溢出处理

  • Rust在调试模式下会检查整数溢出,导致程序在运行时崩溃。
  • 在发布模式下,Rust会进行二进制补码包装,超出范围的值会“回绕”到最小值。

4. 数字运算

Rust支持基本的数学运算,包括加、减、乘、除和取余。示例代码展示了如何在let语句中使用这些运算:

let sum = 5 + 10;
let difference = 95.5 - 4.3;
let product = 4 * 30;
let quotient = 56.7 / 32.2;
let remainder = 43 % 5;

5. 示例

  1. 类型注解示例

    fn main() {let guess: u32 = "42".parse().expect("Not a number!");
    }
    

    该示例展示了如何使用类型注解来指定变量guess的类型为u32

  2. 整数类型示例

    fn main() {let x: (i32, f64, u8) = (500, 6.4, 1);
    }
    

    这里定义了一个元组x,包含不同类型的整数和浮点数。

  3. 浮点数示例

    fn main() {let x = 2.0; // f64let y: f32 = 3.0; // f32
    }
    

    该示例展示了如何声明浮点数变量,默认类型为f64

  4. 布尔类型示例

    fn main() {let t = true;let f: bool = false; // with explicit type annotation
    }
    

    该示例展示了布尔类型的使用,布尔值可以是truefalse

  5. 字符类型示例

    fn main() {let c = 'z';let z: char = 'ℤ'; // with explicit type annotationlet heart_eyed_cat = '😻';
    }
    

    这里展示了如何声明字符类型的变量,Rust的字符类型支持Unicode。

  6. 数组示例

    fn main() {let a = [1, 2, 3, 4, 5];
    }
    

    该示例展示了如何定义一个包含多个整数的数组。

  7. 访问数组元素示例

    fn main() {let a = [1, 2, 3, 4, 5];let first = a[0];let second = a[1];
    }
    

    这里展示了如何通过索引访问数组中的元素。

  8. 无效数组元素访问示例

    use std::io;
    fn main() {let a = [1, 2, 3, 4, 5];println!("Please enter an array index.");let mut index = String::new();io::stdin().read_line(&mut index).expect("Failed to read line");let index: usize = index.trim().parse().expect("Index entered was not a number");let element = a[index];println!("The value of the element at index {index} is: {element}");
    }
    

    此代码编译成功。如果使用cargo run运行此代码并输入01234,程序将打印出数组中该索引处的对应值。如果输入超出数组末尾的数字,例如10,您将看到如下输出:

    thread 'main' panicked at src/main.rs:19:19:
    index out of bounds: the len is 5 but the index is 10
    note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace

    程序在使用无效值进行索引操作时导致了运行时错误。程序以错误信息退出,并未执行最后的println!语句。

  9. 注意:当你尝试使用索引访问元素时,Rust 会检查你指定的索引是否小于数组长度。如果索引大于或等于长度,Rust 程序就会崩溃。因此,这种检查必须在运行时进行,尤其是在这种情况下,因为编译器无法预先知道用户稍后运行代码时会输入什么值。这是Rust的一个内存安全原则:当用户提供错误的索引时,可能会访问到无效的内存。Rust 通过立即退出而不是允许内存访问并继续运行来保护你免受此类错误的影响。

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

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

相关文章

ceph 数据均衡

实现数据均衡的主要方法 在 Ceph 集群中,实现 OSD(对象存储守护进程)之间的数据均衡对于提升性能和资源利用率至关重要。以下是实现数据均衡的主要方法: 1. 调整 OSD 权重(Reweight) 通过调整 OSD 的权重,可以控制数据在各个 OSD 之间的分布。Ceph 提供了根据利用率或…

Proteus-8086调试汇编格式的一点心得

这阵子开始做汇编的微机实验(微机原理与接口技术题解及实验指导,吴宁版本13章),中间出了挺多问题,解决后记录下。 先上电路图 用子电路来仿真发现仿真的时候子电路这块根本没有高低电平输出,只好把子电路拿…

跨界融合:人工智能与区块链如何重新定义数据安全?

引言:数据安全的挑战与现状 在信息化驱动的数字化时代,数据已成为企业和个人最重要的资产之一。然而,随着网络技术的逐步优化和数据量的爆发式增长,数据安全问题也愈变突出。 数据安全现状:– 数据泄露驱动相关事件驱…

机器人碳钢去毛刺,用大扭去毛刺主轴可轻松去除

在碳钢精密加工的最后阶段,去除毛刺是确保产品质量的关键步骤。面对碳钢这种硬度较高的材料,采用大扭矩的SycoTec去毛刺主轴,成为了行业内的高效解决方案。SycoTec作为精密加工领域的领军品牌,其生产的高速电主轴以其卓越的性能&a…

Oracle概述

Oracle概述 Oracle是世界领先的信息管理软件开发商,因其复杂的关系数据库产品而闻名。以下是对Oracle的详细介绍: 一、公司背景与概况 成立时间与地点 :Oracle公司成立于1977年,总部位于美国加州红木滩市(Redwood Shores)。创始人 :由劳伦斯埃里森(Lawrence J. Ellis…

大疆上云API连接遥控器和无人机

文章目录 1、部署大疆上云API关于如何连接我们自己部署的上云API2、开启无人机和遥控器并连接自己部署的上云API如果遥控器和无人机没有对频的情况下即只有遥控器没有无人机的情况下如果遥控器和无人机已经对频好了的情况下 4、订阅无人机或遥控器的主题信息4.1、订阅无人机实时…

LLM的数据并行DDP,模型分片FSDP技术

LLM的数据并行DDP,模型分片FSDP技术: DDP(DistributedDataParallel)技术简介 概念: DDP是PyTorch中用于分布式训练的一种技术。它的核心思想是在多个进程(通常是在多个GPU上)之间并行地训练模型,每个进程都有一份完整的模型副本。这些副本在训练过程中会同步它们的梯度…

[OPEN SQL] 限定选择行数

本次操作使用的数据库表为SCUSTOM&#xff0c;其字段内容如下所示 航班用户(SCUSTOM) 该数据库表中的部分值如下所示 指定查询多少行数据&#xff0c;我们可以使用语法UP TO n ROWS来实现对数据前n项的查询 语法格式 SELECT * FROM <dbtab> UP TO n ROWS 参数说明 db…

机器视觉3-线性分类器

机器视觉3-线性分类器 前言一、整体流程二、其他相关内容 图像的表示图像类型黑白图像灰度图像彩色图像 图像表示为向量一、基本概念二、表示方法三、优点四、局限性五、应用场景 线性分类器一、神经网络的层级结构形成非线性模型二、支撑向量机的高维映射形成非线性模型 线性分…

JavaScript基础概述:脚本定义、输出方式与数据类型

JavaScript是网页开发中的核心技术之一&#xff0c;它赋予网页交互功能和动态效果。 1. JavaScript脚本的定义方式 JavaScript脚本可以通过内联方式或外联方式嵌入到HTML页面中。 内联JS 直接将JavaScript代码写在<script>标签中&#xff1a; <!DOCTYPE html>…

解决“无法定位程序输入点 av_buffer_create 于动态链接库 XXX\Obsidian.exe 上”问题

解决“无法定位程序输入点 av_buffer_create 于动态链接库 XXX\Obsidian.exe 上”问题 问题描述 本人在使用zotero中的zotero one&#xff08;青柠学术插件&#xff09;的时候&#xff0c;使用插件跳转obsidian中的对应笔记&#xff0c;出现上图情况。&#xff08;错误中提到的…

增量导入和全量导入的区别是什么?

定义 全量导入&#xff1a;是指将数据源中的所有数据一次性全部导入到目标系统中。例如&#xff0c;一个电商公司要将其旧数据库中的所有商品信息&#xff08;包括商品名称、价格、库存等&#xff09;全部迁移到新的数据库系统中&#xff0c;这个过程就是全量导入。这种方式会覆…

【数据结构高阶】B-树

目录 一、常见的搜索结构 二、B树 2.1 B树的概念 2.2 B树插入数据的分析 2.3 B树的性能分析 2.4 模拟实现B树 2.4.1 B树节点的定义 2.4.2 B树数据的查找 2.4.3 B树节点的数据插入 2.4.4 B树的遍历 2.4.5 模拟实现B树实现的完整代码 三、B树 3.1 B树的概念 3.2 B树…

《CPython Internals》阅读笔记:p97-p117

《CPython Internals》学习第 7 天&#xff0c;p97-p117 总结&#xff0c;总计 21 页。 一、技术总结 1.词法分析(lexical analysis) 根据《Compilers-Principles, Techniques, and Tools》(《编译原理》第2版)第 5 页&#xff1a;The first phase of a compiler is called …

2.两数相加--力扣

给你两个 非空 的链表&#xff0c;表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的&#xff0c;并且每个节点只能存储 一位 数字。 请你将两个数相加&#xff0c;并以相同形式返回一个表示和的链表。 你可以假设除了数字 0 之外&#xff0c;这两个数都不会以 0 …

第31章 汇编语言--- 安全性考量

汇编语言是一种低级编程语言&#xff0c;它与特定的计算机架构紧密相关。编写安全的汇编代码是至关重要的&#xff0c;因为汇编代码直接操作硬件和内存&#xff0c;任何错误都可能导致严重的后果&#xff0c;如系统崩溃、数据泄露或被恶意利用。在第31章中讨论汇编语言的安全性…

2501d,d作者,炮打C语言!

原文 标准C定期改进,现在为C23.但是还是没有解决一些怪东西.Dlang社区在D语言编译器中嵌入了一个C编译器,这样可编译C. 该C编译器(又名ImportC)是从头开始构建的.它提供了使用现代编译器技术来修复这些缺点的机会.为什么标准C不修复它们? 1,计算常式 2,编译时单元测试 3,前…

口碑很好的国产LDO芯片,有哪些?

在几乎任何一个电路设计中&#xff0c;都可能会使用LDO&#xff08;低压差线性稳压器&#xff09;这个器件。 虽然LDO不是什么高性能的IC&#xff0c;但LDO芯片市场竞争异常激烈。最近几年&#xff0c;诞生了越来越多的精品国产LDO&#xff0c;让人看得眼花缭乱。 业内人士曾经…

搜索引擎的设计与实现【源码+文档+部署讲解】

目 录 目 录 1 绪论 1.1 项目背景 1.2 国内外发展现状及分类 1.3 本论文组织结构介绍 2 相关技术介绍 2.1什么是搜索引擎 2.2 sqlserver数据库 2.3 Tomcat服务器 3 搜索引擎的基本原理 3.1搜索引擎的基本组成及其功能 3.2搜索引擎的详细工作流程 4 系统分析与…

计算机系统组成(计算机组成原理 基础)

文章目录&#xff1a; 一&#xff1a;体系结构 1.系统组成 1.1 硬件系统 1.2 软件系统 2.工作原理 2.1 冯诺依曼体系 2.2 指令和指令系统 3.性能指标 二&#xff1a;硬件系统 1.主机 1.1 CPU 1.2 内存 2.外设 2.1 外存 2.2 输入设备 2.3 输出设备 2.4 适配器 …