由于 serde 库默认使用 JSON 格式进行序列化和反序列化
因此程序将使用 JSON 格式对数据进行序列化和反序列化
use serde::{
Serialize, Deserialize};
// `derive` may only be applied to `struct`s, `enum`s and `union`s
#[derive(Serialize, Deserialize, Debug)]
struct Animal {
name: String,
age: u32,
}
fn main() {
let animal = Animal {
name: "Dog".to_owned(),
age: 1,
};
let json_str = serde_json::to_string(&animal).unwrap();
println!("{}", json_str);
let json_str1 = r#"{"name":"Dog","age":1}"#;
// 编译器无法推断变量或函数的类型,并需要使用类型注解来明确指定类型
let animal1: Animal = serde_json::from_str(json_str1).unwrap();
println!("{:?}", animal1)
}
use serde::{
Serialize, Deserialize, Serializer, Deserializer};
#[derive(Serialize, Deserialize, Debug)]
struct Animal {
#[serde(rename = "animal_name")]
NaMe: String,
#[serde(rename = "animal_age")]
AgE: u32,
}
fn main() {
let animal = Animal {
NaMe: "Dog".to_owned(),
AgE: 1,
};
let json_str = serde_json::to_string(&animal).unwrap();
println!("{}", json_str);
let json_str1 = r#"{"animal_name":"Dog","animal_age":1}"#;
// 编译器无法推断变量或函数的类型,并需要使用类型注解来明确指定类型
let animal1: Animal = serde_json::from_str(json_str1).unwrap();
println!("{:?}", animal1)
}
打印内容如下
{
"animal_name":"DOG","animal_age":1}
Animal {
NaMe: "dog", AgE: 1 }
该场景在业务中貌似不会用到!!!
use serde::{
Serialize, Deserialize, Serializer, Deserializer};
#[derive(Serialize, Deserialize, Debug)]
struct Animal {
#[serde(serialize_with = "serialize_name", deserialize_with = "deserialize_name")]
// 上述serde仅处理Nme
NaMe: String,
AgE: u32,
}
// 使用 serde 库自定义的序列化和反序列化函数
// 在序列化和反序列化期间自定义字段的名称,并使用自定义的名称序列化和反序列化数据
fn serialize_name<S>(name: &String, serializer: S) -> Result<S::Ok, S::Error>
where
S: Serializer,
{
// 将输入字符串转换为大写并序列化
serializer.serialize_str(&name.to_uppercase())
}
fn deserialize_name<'de, D>(deserializer: D) -> Result<String, D::Error>
where
D: Deserializer<'de>,
{
let name = String::deserialize(deserializer)?;
// 获取输入字符串 name,并使用 name.to_lowercase() 将其转换为小写形式
Ok(name.to_lowercase())
}
fn main() {
let animal = Animal {