Rust教程:How to Rust-基本类型

这篇具有很好参考价值的文章主要介绍了Rust教程:How to Rust-基本类型。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

专栏简介

本专栏是优质Rust技术专栏,推荐精通一门技术栈的蟹友,不建议完全无计算机基础的同学

感谢Rust圣经开源社区的同学,为后来者提供了非常优秀的Rust学习资源

本文使用:

  • 操作系统macOS Sonoma 14 / Apple M1
  • 编译器:Rustc & Cargo

感谢一路相伴的朋友们,感谢你们的支持 ^ _ ^

Rust教程:How to Rust-基本类型


目录

专栏简介

更新记录

前言

整型

整型溢出

浮点型

NaN

 使用As进行类型转换

结语

本文参考文献


更新记录

2024.3.24 发布文章


前言

Rust中的整型怎么写?整型溢出会怎么样?浮点型呢?NaN是什么?如何进行类型转换?


整型

Rust的类型系统与其他编程语言有许多相似之处,但Rust对类型的处理有其独特之处。在Rust中,整数类型的符号大小直接体现在类型名称中,这有助于清晰地表达每个类型的取值范围。

Rust的整数类型如下:

Rust整数类型
长度 有符号类型 无符号类型
8位 i8 u8
16位 i16

u16

32位 i32 u32
64位 i64

u64

128位 i128 u128
视架构 isize usize

类型定义的形式统一为:有无符号 + 大小(位数)。无符号数表示数字只能取正数和0,而有符号则表示数字可以取正数、负数以及0。就像我们在纸上写数字一样,当需要强调符号时,数字前面可以带上正号或负号;然而,当很明显确定数字为正数时,就不需要加上正号了。有符号数字在Rust中是以补码形式存储的。

在Rust编程语言中,isizeusize是两个与平台相关的整数类型。它们的大小取决于目标机器的指针大小。isize是一个有符号整数类型,其大小与机器的字大小相同。在32位系统上,isize通常是32位;在64位系统上,isize通常是64位。usize则是相应的无符号版本。

整型溢出

关于整型溢出,Rust有一些特别的规则。当在debug模式编译时,Rust会检查整型溢出,并在发现溢出时使程序panic(即崩溃)。然而,在release模式下编译时,Rust不检测溢出,而是按照补码循环溢出的规则处理。这意味着大于该类型最大值的数值会被转换成该类型能够支持的对应的最小值。例如,在u8类型中,256会变成0,257会变成1,以此类推。

为了显式处理可能的溢出,Rust标准库为原始数字类型提供了一系列方法:

  • 使用wrapping_*方法在所有模式下都按照补码循环溢出规则处理,例如wrapping_add
  • 如果使用checked_*方法时发生溢出,则返回None值。
  • 使用overflowing_*方法返回该值和一个指示是否存在溢出的布尔值。
  • 使用saturating_*方法,可以限定计算后的结果不超过目标类型的最大值或不低于最小值。

例如:

let result1 = (250_u8).wrapping_add(10); // 结果是 4
let result2 = (120_i8).wrapping_add(10); // 结果是 -126
let result3 = (300_u16).wrapping_mul(800); // 结果是 43392
let result4 = (-100_i8).wrapping_sub(100); // 结果是 56

在这些例子中,wrapping_*方法用于在溢出时按照补码循环溢出的规则进行处理,而不是使程序崩溃。然而,需要注意的是,依赖这种默认行为的代码通常被认为是错误的,因为它可能导致程序中的逻辑错误或数据损坏。在编写涉及整数运算的代码时,应该仔细考虑如何处理可能的溢出情况,并使用适当的方法来检查或处理它们


浮点型

浮点类型数字是带有小数点的数值,在Rust中,主要有两种浮点类型:f32f64,分别对应32位和64位大小的浮点数。默认情况下,Rust使用f64作为浮点类型,因为在现代CPU上,尽管f32f64的速度相差无几,但f64提供了更高的精度。

let variable_float = 2.0;
let variable_f32: f32 = 3.0;

变量variable_float的类型是默认的f64,而变量variable_f32的类型则是显式声明的f32。当然,你也可以显式声明f64类型的变量,例如:

let variable_f64: f64 = 4.0;

使用浮点数时,如果不谨慎,可能会带来一些潜在的危险。这主要有两个原因:

首先,浮点数通常是用来近似表达你想要的数值。请注意,这里的“近似表达”是因为浮点数类型是基于二进制实现的,而我们通常使用的数字则是基于十进制的。例如,数值0.1在二进制中无法精确表示,这导致了一定的歧义。尽管浮点数能够代表真实的数值,但由于其底层格式的限制,它通常受限于定长的浮点数精度。如果你需要表达完全精确的真实数字,则需要使用具有无限精度的数学库。

其次,浮点数在某些特性上是反直觉的。虽然可以使用>>=等运算符对浮点数进行比较,但在某些场景下,这种直觉上的比较特性可能会导致错误。f32f64上的比较运算实现了std::cmp::PartialEq特性,但并没有实现std::cmp::Eq特性,而后者在其他数值类型上都有定义。

来看个例子

fn main()
{
    assert_eq!(0.1 + 0.2, 0.3); // 这行代码会触发 panic,因为二进制精度问题导致 0.1 + 0.2 不严格等于 0.3
}

上述代码中,第三行是一个断言,断言0.1 + 0.2的结果就是0.3。然而,由于二进制精度的问题,0.1 + 0.2并不严格等于0.3,它们之间可能存在小数点后某位的误差,这与大多数编程语言中的浮点数行为是一致的。

NaN

对于数学上未定义的结果,如负数开平方根,Rust的浮点数类型会使用NaN(Not a Number)来处理这些情况。任何与NaN进行交互的操作都会返回NaN,并且NaN不能用于比较(如断言),这会导致程序崩溃。

例如,以下代码会产生NaN:

fn main()
{
    let variable = (-1.1_f64).sqrt();
}

为了避免程序因NaN而崩溃,我们可以使用一些方法来检查数值是否为NaN,例如使用.is_nan()方法:

fn main()
{
    let variable = (-1.1_f64).sqrt();
    if variable.is_nan()
    {
        println!("NaN")
    }
}

使用.is_nan()可以帮助我们安全地处理可能产生NaN的浮点数运算。 

 使用As进行类型转换

在Rust中,as关键字用于在原始类型(如i64f64u64char等)之间进行类型转换。然而,需要注意的是,as关键字并不适用于复合类型,比如String或其他用户定义的类型。对于复合类型的转换,通常需要使用其他方法或函数。

例如,如果你有一个i32类型的变量,并希望将其转换为f64类型的浮点数,你可以使用as关键字来实现这一转换:

let num_i32: i32 = 42;  
let num_f64: f64 = num_i32 as f64;

但是,as关键字的使用是有限制的,它只能在那些具有明确定义转换规则的类型之间起作用。如果尝试在不兼容的类型之间进行转换,Rust编译器会报错。例如,下面的代码尝试将一个String转换为i32,这是不允许的,因为Stringi32之间没有直接的转换关系:

let str_num = "123".to_string();  
let num_i32: i32 = str_num as i32; // 这行会报错,因为 String 不能直接转换为 i32

在上面的代码中,尝试使用as来转换str_num变量会导致编译错误,因为String类型不能直接用as关键字转换为i32类型。如果需要将字符串转换为整数,你需要使用其他方法,比如parse方法:

let str_num = "123";  
let num_i32: i32 = str_num.parse().unwrap(); // 使用 parse 方法来将字符串转换为整数

在上面的代码中,我们使用了parse()方法,该方法尝试将字符串解析为相应的数值类型,并返回一个Result枚举,表示解析操作是否成功。使用unwrap()方法可以获取解析结果,但如果解析失败(比如字符串不是有效的数字表示),则会触发panic。在实际应用中,通常需要对parse()的返回值进行更健壮的错误处理。

因此,在使用as进行类型转换时,需要确保转换的类型之间具有明确定义的转换关系,并且不适用于复合类型或没有直接转换关系的类型。对于更复杂的类型转换需求,需要利用Rust提供的相应函数或方法。


结语

如果本文有任何问题欢迎在评论去指出,如果喜欢这篇文章,希望能点赞评论关注

如果你们身边有像你提起过这个领域的,或者希望可以和ta一起进步的,把这篇文章分享给ta吧

本文共3646字


本文参考文献

Rust圣经

文心一言 

菜鸟求助,使用 isize 或 usize 作为索引类型更加灵活 - Rust语言中文社区

在 Rust 中处理整数溢出

https://www.cnblogs.com/ywxt/p/11801778.html文章来源地址https://www.toymoban.com/news/detail-848512.html

到了这里,关于Rust教程:How to Rust-基本类型的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Rust语言精讲:数据类型全解析

    大家好!我是lincyang。 今天,我们将深入探讨Rust语言中的数据类型,这是理解和掌握Rust的基础。 Rust语言数据类型概览 Rust是静态类型语言,所有变量类型在编译时确定。Rust的数据类型分为两类:标量类型和复合类型。 标量类型 标量类型是单一值的类型,包括整型、浮点型

    2024年02月05日
    浏览(47)
  • Rust语言中级教程之指针

    指针是计算机引用无法立即直接访问的数据的一种方式(类比 书的目录) 数据在物理内存(RAM)中是分散的存储着 地址空间是检索系统 指针就被编码为内存地址,使用 usize 类型的整数表示。 一个地址就会指向地址空间中的某个地方 地址空间的范围是 OS 和 CPU 提供的外观界

    2024年02月02日
    浏览(34)
  • Rust语言从入门到入坑——(2)Rust在windows上搭建开发环境

    开始搭建一个适合在windows上运行的Rust环境。 Rust支持的程序语言很多:可详见官网介绍 本文章主要是在windowns下搭建开发环境 首先,需要安装最新版的 Rust 编译工具和 Visual Studio Code。 Rust 编译工具:https://www.rust-lang.org/zh-CN/tools/install Visual Studio Code:https://code.visualstudio.com

    2024年02月09日
    浏览(52)
  • Rust软件外包开发语言的特点

    Rust 是一种系统级编程语言,强调性能、安全性和并发性的编程语言,适用于广泛的应用领域,特别是那些需要高度可靠性和高性能的场景。下面和大家分享 Rust 语言的一些主要特点以及适用的场合,希望对大家有所帮助。北京木奇移动技术有限公司,专业的软件外包开发公

    2024年02月12日
    浏览(51)
  • 如何用Rust语言构建一个基本的区块链应用,并用实际案例来演示区块链的工作原理和应用

    作者:禅与计算机程序设计艺术 在区块链领域,已经出现了很多种不同的方案,从最原始的比特币到现如今的基于分布式数据库的各类公链系统等等。这些方案都采用了区块链技术,用来解决“去中心化”、“可追溯”和“安全”的问题。虽然各有千秋,但是作为一名合格的

    2024年02月10日
    浏览(60)
  • 【Rust 基础篇】Rust 枚举类型

    在 Rust 中,枚举类型(Enum)是一种自定义数据类型,它允许我们定义一个值只能取自预定义列表中的变量。枚举类型在编写代码时可以提供更明确的语义,使得代码更易于理解和维护。本篇博客将详细介绍 Rust 中的枚举类型,包括定义、使用和模式匹配等方面的内容。 在

    2024年02月12日
    浏览(38)
  • 【Rust 基础篇】Rust数据类型详解

    Rust是一种现代的、安全的系统编程语言,注重内存安全和并发性。在Rust中,数据类型是程序中最基本的构建块之一。本篇博客将详细解释Rust的各种数据类型,并提供相关代码示例。 Rust的基本数据类型包括布尔类型、整数类型、浮点类型和字符类型。 1、布尔类型(bool) 布

    2024年02月11日
    浏览(53)
  • 【Rust 基础篇】Rust String 类型详解

    在 Rust 中,String 是一种动态可变的字符串类型,它提供了对字符串的灵活操作和修改能力。与字符串字面量(string literals)不同,String 类型是可变的,可以根据需要进行修改。本篇博客将详细介绍 Rust 中的 String 类型,包括定义、常用方法和使用示例。 在 Rust 中,可以使用

    2024年02月12日
    浏览(41)
  • Rust之通用集合类型

    在Rust语言中包含了一系列被称为集合的数据结构。大部分的数据结构都代表着某个特定的值,但集合却可以包含多个值。与内置的数组与元组类型不同,这些集合将自己持有的数据存储在了堆上。这意味着数据的大小不需要在编译时确定,并且可以随着程序的运行按需扩大或

    2024年02月15日
    浏览(40)
  • Rust-类型

    布尔类型(bool)代表的是“是”和“否”的二值逻辑。它有两个值:true和false。 一般用在逻辑表达式中,可以执行“与”“或”“非”等运算。 字符类型由char表示。它可以描述任何一个符合unicode标准的字符值。在代码中,单个的字符字面量用单引号包围。 字符类型字面量也

    2024年01月16日
    浏览(50)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包