Rust格式化输出方式总结

2025-02-26 17:50

本文主要是介绍Rust格式化输出方式总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《Rust格式化输出方式总结》Rust提供了强大的格式化输出功能,通过std::fmt模块和相关的宏来实现,主要的输出宏包括println!和format!,它们支持多种格式化占位符,如{}、{:?}...

Rust格式化输出方式

Rust的格式化输出是通过std::fmt模块提供的强大功能来实现的。

Rust提供了灵活且dYcvH功能强大的格式化字符串语法,允许开发者根据需求输出不同类型的数据。

基本的格式化输出

Rust中最常用的格式化输出方法是使用println!和format!宏。

这些宏通过std::fmt::Display和std::fmt::Debug trwww.chinasem.cnait来控制输出的格式。

  • print!将格式化文本输出到标准输出,不带换行符
  • println!同上,但是在行的末尾添加换行符
  • format!将格式化文本输出到String字符串

1.使用println!宏

let name = "Alice";
let age = 30;
//{} 是占位符,它会被后续传入的变量name和age替换  
println!("Hello, my name is {} and I am {} years old.", name, age); 

使用format!宏

  • format!用法与println!类似,不过它返回一个格式化的String而不是直接输出。
  • format!宏在生成字符串时很有用,特别是当你需要在多个地方使用格式化字符串时。
let name = "Alice";
let age = 30;
let message = format!("Hello, my name is {} and I am {} years old.", name, age);
println!("{}", message);

格式化占位符

Rust的格式化占位符{}有多种变体,用于处理不同的数据类型和输出需求。

1.默认显示格式:{}

{}是最常见的占位符,适用于实现了Display trait的类型,比如字符串和大多数数值类型。

let x = 10;
println!("The value of x is {}", x);

2.调试格式{:?} 和 {:#?}

对于Debug trait类型的变量使用{:?}来打印它们的www.chinasem.cn调试信息。

例如结构体、枚举和集合类型通常需要Debug trait来实现。

#[derive(Debug)]
struct Point {
    x: i32,
    y: i32,
}

let p = Point { x: 1, y: 2 };
println!("Debug output: {:?}", p);

{:#?}会以更具可读性的格式打印数据(通常用于打印集合和结构体等复杂类型)

println!("Pretty Debug: {:#?}", p);

3.自定义格式{:<width}、{:>width}和{:^width}

  • {:<width}:左对齐
  • {:www.chinasem.cn>width}:右对齐
  • {:^width}:居中对齐
//填充对齐
fn main() {
    // 以下全部都会补齐5个字符的长度
    // 左对齐 => Hello x    !
    println!("Hello {:<5}!", "x");
    // 右对齐 => Hello     x!
    println!("Hello {:>5}!", "x");
    // 居中对齐 => Hello   x  !
    println!("Hello {:^5}!", "x");
    // 对齐并使用指定符号填充 => Hello x&&&&!
    // 指定符号填充的前提条件是必须有对齐字符
    println!("Hello {:&<5}!", "x");
}

4.指定精度 {:.precision}

对于浮点数,可以使用 {:.precision} 来控制小数点后的位数。

let pi = 3.141592653589793;
println!("Pi with 2 decimals: {:.2}", pi); // 输出:3.14

//精度可以用于控制浮点数的精度或者字符串的长度  
fn main() {
    let v = 3.1415926;
    //保留小数点后两位 => 3.14
    println!("{:.2}", v);
    //带符号保留小数点后两位 => +3.14
    println!("{:+.2}", v);
    //不带小数 => 3
    println!("{:.0}", v);
    //通过参数来设定精度 => 3.1416,相当于{:.4}
    println!("{:.1$}", v, 4);

    let s = "hi我是Sunface飞飞";
    //保留字符串前三个字符 => hi我
    println!("{:.3}", s);
    //{:.*}接收两个参数,第一个是精度,第二个是被格式化的值 => Hello abc!
    println!("Hello {:.*}!", 3, "abcdefg");
}

5.带符号的格式 {:+}和{:0>width}

  • {:+}: 如果值是正数,显示+符号
  • {:0>width}: 数字宽度不足时,用0填充 右对齐。
//固定符号填充 
fn main() {
    // 宽度是5 => Hello     5!
    println!("Hello {:5}!", 5);
    // 显式的输出正号 => Hello +5!
    println!("Hello {:+}!", 5);
    // 宽度5,使用0进行填充 => Hello 00005!
    println!("Hello {:05}!", 5);
    // 负号也要占用一位宽度 => Hello -0005!
    println!("Hello {:05}!", -5);
}

6.十六进制、二进制、八进制格式:{:x}、{:X}、{:b}、{}

//进制
//#b, 二进制
//#o, 八进制
//#x, 小写十六进制
//#X, 大写十六进制
//x, 不带前缀的小写十六进制
fn main() {
    // 二进制 => 0b11011!
    println!("{:#b}!", 27);
    // 八进制 => 0o33!
    println!("{:#o}!", 27);
    // 十进制 => 27!
    println!("{}!", 27);
    // 小写十六进制 => 0x1b!
    println!("{:#x}!", 27);
    // 大写十六进制 => 0x1B!
    println!("{:#X}!", 27);

    // 不带前缀的十六进制 => 1b!
    println!("{:x}!", 27);

    // 使用0填充二进制,宽度为10 => 0b00011011!
    println!("{:#010b}!", 27);
}

7.具名参数输出

//{1},表示用第二个参数替换该占位符(索引从 0 开始)
fn main() {
    println!("{}{}", 1, 2); // =>"12"
    println!("{1}{0}", 1, 2); // =>"21"
    println!("{0}, this is {1}. {1}, this is {0}", "Alice", "Bob");

}
//具名参数  
//带名称的参数必须放在不带名称参数的后面   
fn main() {
    println!("{argument}", argument = "test"); // => "test"
    println!("{name} {}", 1, name = 2); // => "2 1"
    println!("{a} {c} {b}", a = "a", b = 'b', c = 3); // => "a 3 b"
}

Format 特性

Rust的类型系统允许你定义自己的格式化方式。通过实现std::fmt::Display和std::fmt::Debug特性,自定义格式化输出。

1.实现 Display trait

fn main() {
    use std::fmt;
    struct Circle {
    radius: f64,
    }
    impl fmt::Display for Circle {
    fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
        write!(f, "Circle with radius {:.2}", self.radius)
    }
    }
    let circle = Circle { radius: 5.0 };
    //输出: Circle with radius 5.00  
    println!("{}", circle);
}

2.实现 Debug trait

fn main() {
    use std::fmt;

    struct Rectangle {
    width: u32,
    height: u32,
    }

    impl fmt::Debug for Rectangle {
        fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
            write!(f, "Rectangle {{ width: {}, height: {} }}", self.width, self.height)
        }
    }

    let rect = Rectangle { width: 10, height: 5 };
    //输出: Rectangle { width: 10, height: 5 }
    println!("{:?}", rect); 
}

总结

Rust的格式化输出功能非常强大,支持多种数据类型的自定义输出格式。

常见的输出宏包括println!和format!,它们结合不同的格式化占位符和数据类型可以满足大多数输出需求。

使用 {} 进行简单的输出。

使用 {:?} 或 {:#?} 输出调试信javascript息。

格式化选项如 {:width}, {:.precision}, {:+}, {:x} 等提供了灵活的输出控制。

通过实现 Display 或 Debug trait,你可以为自定义类型提供格式化输出。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持China编程(www.chinasem.cn)。

这篇关于Rust格式化输出方式总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1153552

相关文章

python判断文件是否存在常用的几种方式

《python判断文件是否存在常用的几种方式》在Python中我们在读写文件之前,首先要做的事情就是判断文件是否存在,否则很容易发生错误的情况,:本文主要介绍python判断文件是否存在常用的几种... 目录1. 使用 os.path.exists()2. 使用 os.path.isfile()3. 使用

SQL中JOIN操作的条件使用总结与实践

《SQL中JOIN操作的条件使用总结与实践》在SQL查询中,JOIN操作是多表关联的核心工具,本文将从原理,场景和最佳实践三个方面总结JOIN条件的使用规则,希望可以帮助开发者精准控制查询逻辑... 目录一、ON与WHERE的本质区别二、场景化条件使用规则三、最佳实践建议1.优先使用ON条件2.WHERE用

Mybatis的分页实现方式

《Mybatis的分页实现方式》MyBatis的分页实现方式主要有以下几种,每种方式适用于不同的场景,且在性能、灵活性和代码侵入性上有所差异,对Mybatis的分页实现方式感兴趣的朋友一起看看吧... 目录​1. 原生 SQL 分页(物理分页)​​2. RowBounds 分页(逻辑分页)​​3. Page

Linux链表操作方式

《Linux链表操作方式》:本文主要介绍Linux链表操作方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、链表基础概念与内核链表优势二、内核链表结构与宏解析三、内核链表的优点四、用户态链表示例五、双向循环链表在内核中的实现优势六、典型应用场景七、调试技巧与

Linux实现线程同步的多种方式汇总

《Linux实现线程同步的多种方式汇总》本文详细介绍了Linux下线程同步的多种方法,包括互斥锁、自旋锁、信号量以及它们的使用示例,通过这些同步机制,可以解决线程安全问题,防止资源竞争导致的错误,示例... 目录什么是线程同步?一、互斥锁(单人洗手间规则)适用场景:特点:二、条件变量(咖啡厅取餐系统)工作流

RedisTemplate默认序列化方式显示中文乱码的解决

《RedisTemplate默认序列化方式显示中文乱码的解决》本文主要介绍了SpringDataRedis默认使用JdkSerializationRedisSerializer导致数据乱码,文中通过示... 目录1. 问题原因2. 解决方案3. 配置类示例4. 配置说明5. 使用示例6. 验证存储结果7.

Nginx Location映射规则总结归纳与最佳实践

《NginxLocation映射规则总结归纳与最佳实践》Nginx的location指令是配置请求路由的核心机制,其匹配规则直接影响请求的处理流程,下面给大家介绍NginxLocation映射规则... 目录一、Location匹配规则与优先级1. 匹配模式2. 优先级顺序3. 匹配示例二、Proxy_pa

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

Python程序打包exe,单文件和多文件方式

《Python程序打包exe,单文件和多文件方式》:本文主要介绍Python程序打包exe,单文件和多文件方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录python 脚本打成exe文件安装Pyinstaller准备一个ico图标打包方式一(适用于文件较少的程

Python验证码识别方式(使用pytesseract库)

《Python验证码识别方式(使用pytesseract库)》:本文主要介绍Python验证码识别方式(使用pytesseract库),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全... 目录1、安装Tesseract-OCR2、在python中使用3、本地图片识别4、结合playwrigh