rust语言学习笔记Trait之Debug、Display

Debug 开发者调试

  • Debug 用于调试输出,紧凑输出:{:?}、美化输出:{:#?}
  • 通常自动派生:#[derive(Debug)]
  • 自动派生时输出字段名、完整结构信息,也可以手动实现:impl std::fmt::Debug
  • 用于:日志记录、单元测试、开发阶段打印变量
  • 注意:由于 Debug 自动派生时输出包含所有字段,‌切勿 ‌在 Debug 输出中包含密码、密钥等敏感信息,或者在手动实现时将其掩码处理。

Display 用户展示

  • Display 用于自定义用户输出:{}

  • 必须手动实现:impl std::fmt::Display

  • 输出简洁、友好、正式,旨在让最终用户易读

  • 用于:CLI 工具输出、API 响应、错误提示消息

Debug 使用

Debug自动派生

rust 复制代码
#[derive(Debug)]     // 自动实现 Debug
struct User {
    id: usize,
    username: String,
    password: String,
}

fn main() {
    let user = User{id:1,username:"xiao".to_string(),password:"abc123".to_string()};
    println!("{:?}",user);    // 调试输出紧凑模式
    println!("{:#?}",user);   // 调试输出美化模式
}

程序输出:

bash 复制代码
# {:?}   调试输出紧凑模式
User { id: 1, username: "xiao", password: "abc123" }

# {:#?}  调试输出美化模式
User {
    id: 1,
    username: "xiao",
    password: "abc123",
}

Debug 手动实现 impl std::fmt::Debug(未区分美化模式)

rust 复制代码
use std::fmt;

struct User {
    id: usize,
    username: String,
    password: String,
}

impl fmt::Debug for User {
    fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
        write!(f, "User{{id={},username={}}}",self.id, self.username )
    }
}

fn main() {
    let user = User{id:1,username:"xiao".to_string(),password:"abc123".to_string()};
    println!("{:?}",user);    // 调试输出紧凑模式
    println!("{:#?}",user);   // 调试输出美化模式
}

程序输出:

bash 复制代码
# {:?}   调试输出紧凑模式
User{id=1,username="xiao"}

# {:#?}  调试输出美化模式
User{id=1,username="xiao"}

Debug 手动实现 impl std::fmt::Debug(区分美化模式)

rust 复制代码
use std::fmt;

struct User {
    id: usize,
    username: String,
    password: String,
}

impl fmt::Debug for User {
    fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
        if f.alternate(){
            // 当使用 {:#?} 时,f.alternate() 为 true
            write!(f, "User{{\n    id={},\n    username={}\n}}",self.id, self.username )
        }else{
            // 当使用 {:?} 时,f.alternate() 为 false
            write!(f, "User{{id={},username={}}}",self.id, self.username )
        }
    }
}

fn main() {
    let user = User{id:1,username:"xiao".to_string(),password:"abc123".to_string()};
    println!("{:?}",user);    // 调试输出紧凑模式
    println!("{:#?}",user);   // 调试输出美化模式
}

程序输出:

bash 复制代码
# {:?}   调试输出紧凑模式
User{id=1,username="xiao"}

# {:#?}  调试输出美化模式
User{
    id=1,
    username="xiao"
}

Display 的使用

rust 复制代码
use std::fmt;

#[derive(Debug)]   // 实现 Display 不影响 Debug 的使用
struct User {
    id: usize,
    username: String,
    password: String,
}

// Display 必须手动实现
impl fmt::Display for User {
    fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
        write!(f, "您的id:{},您的用户名:{}",self.id, self.username )
    }
}

fn main() {
    let user = User{id:1,username:"xiao".to_string(),password:"abc123".to_string()};
    println!("{:?}",user);    // Debug 调试输出紧凑模式
    println!("{:#?}",user);   // Debug 调试输出美化模式
    
    // 实现 Display 的输出
    println!("{}",user);
}

程序输出:

bash 复制代码
# {:?}   Debug 调试输出紧凑模式
User { id: 1, username: "xiao", password: "abc123" }

# {:#?}  Debug 调试输出美化模式
User {
    id: 1,
    username: "xiao",
    password: "abc123",
}

# {}  Display 的输出
您的id:1,您的用户名:abc123
相关推荐
一尘之中5 小时前
从C语言底层设计到系统架构评估:软件架构知识体系全景
学习·系统架构·ai写作
sheeta19986 小时前
LeetCode 每日一题笔记 日期:2026.05.29 题目:3300. 最小元素
笔记·leetcode
中屹指纹浏览器7 小时前
2026指纹浏览器代理链路适配原理与多线路集群调度方案
经验分享·笔记
星夜夏空997 小时前
FreeRTOS学习(4)——内存映射
数据库·学习·mongodb
不羁的木木7 小时前
ArkWeb实战学习笔记05-综合实战:构建混合应用
笔记·学习·harmonyos
橙橙笔记7 小时前
Python的学习第一部分
python·学习
bush47 小时前
嵌入式linux学习记录二
linux·运维·学习
CC大煊7 小时前
一个Javaer的AI转型笔记(1):入坑LangChain,我的第一个hello world
笔记·langchain
元气少女小圆丶9 小时前
SenseGlove Nova 2+Unity开发笔记1
笔记·学习·unity
nashane10 小时前
HarmonyOS 6学习:应用退出动画优化实战——从“闪退“到优雅退出的完美蜕变
学习·华为·harmonyos