当前位置: 首页 > news >正文

建筑工程网站建设柳市网站制作

建筑工程网站建设,柳市网站制作,做传销网站,网站建设预算申请基本类型转换 // 不显示类型转换产生的溢出警告。 #![allow(overflowing_literals)]fn main() {let decimal 65.4321_f32;// 错误!不提供隐式转换// let integer: u8 decimal;// 可以显式转换let integer decimal as u8;let character integer as char;println…

基本类型转换

// 不显示类型转换产生的溢出警告。
#![allow(overflowing_literals)]fn main() {let decimal = 65.4321_f32;// 错误!不提供隐式转换// let integer: u8 = decimal;// 可以显式转换let integer = decimal as u8;let character = integer as char;println!("Casting: {} -> {} -> {}", decimal, integer, character);// 当把任何类型转换为无符号类型 T 时,会不断加上或减去 (std::T::MAX + 1)// 直到值位于新类型 T 的范围内。// 1000 已经在 u16 的范围内println!("1000 as a u16 is: {}", 1000 as u16);// 1000 - 256 - 256 - 256 = 232// 事实上的处理方式是:从最低有效位(LSB,least significant bits)开始保留// 8 位,然后剩余位置,直到最高有效位(MSB,most significant bit)都被抛弃。// 译注:MSB 就是二进制的最高位,LSB 就是二进制的最低位,按日常书写习惯就是// 最左边一位和最右边一位。println!("1000 as a u8 is : {}", 1000 as u8);// -1 + 256 = 255println!("  -1 as a u8 is : {}", (-1i8) as u8);// 对正数,这就和取模一样。println!("1000 mod 256 is : {}", 1000 % 256);// 当转换到有符号类型时,(位操作的)结果就和 “先转换到对应的无符号类型,// 如果 MSB 是 1,则该值为负” 是一样的。// 当然如果数值已经在目标类型的范围内,就直接把它放进去。println!(" 128 as a i16 is: {}", 128 as i16);// 128 转成 u8 还是 128,但转到 i8 相当于给 128 取八位的二进制补码,其值是:println!(" 128 as a i8 is : {}", 128 as i8);// 重复之前的例子// 1000 as u8 -> 232println!("1000 as a u8 is : {}", 1000 as u8);// 232 的二进制补码是 -24println!(" 232 as a i8 is : {}", 232 as i8);
}
Casting: 65.4321 -> 65 -> A
1000 as a u16 is: 1000
1000 as a u8 is : 232-1 as a u8 is : 255
1000 mod 256 is : 232128 as a i16 is: 128128 as a i8 is : -128
1000 as a u8 is : 232232 as a i8 is : -24

From

根据其他类型生成自己

use std::convert::From;#[derive(Debug)]
struct Number {value: i32,
}impl From<i32> for Number {fn from(item: i32) -> Self {Number { value: item }}
}fn main() {// 左边不需要类型,右边类似构造let num = Number::from(30);println!("My number is {:?}", num);
}
let my_str = "hello";
let my_string = String::from(my_str);

Into

把其他类型转为目的类型

use std::convert::From;#[derive(Debug)]
struct Number {value: i32,
}// 有了From,就自然有了Into
impl From<i32> for Number {fn from(item: i32) -> Self {Number { value: item }}
}fn main() {let int = 5;// 左边需要类型,右边才能推断// a类型可根据c类型构造,b类型也可根据c类型构造// 如果让c类型直接into,c不知道是转为a还是blet num: Number = int.into();println!("My number is {:?}", num);
}

TryFrom 和 TryInto

use std::convert::TryFrom;
use std::convert::TryInto;#[derive(Debug, PartialEq)]
struct EvenNumber(i32);impl TryFrom<i32> for EvenNumber {type Error = ();fn try_from(value: i32) -> Result<Self, Self::Error> {if value % 2 == 0 {Ok(EvenNumber(value))} else {Err(())}}
}fn main() {// TryFromassert_eq!(EvenNumber::try_from(8), Ok(EvenNumber(8)));assert_eq!(EvenNumber::try_from(5), Err(()));// TryIntolet result: Result<EvenNumber, ()> = 8i32.try_into();assert_eq!(result, Ok(EvenNumber(8)));let result: Result<EvenNumber, ()> = 5i32.try_into();assert_eq!(result, Err(()));
}

ToString

要把任何类型转换成 String,只需要实现那个类型的 ToString trait

use std::string::ToString;struct Circle {radius: i32
}impl ToString for Circle {fn to_string(&self) -> String {format!("Circle of radius {:?}", self.radius)}
}fn main() {let circle = Circle { radius: 6 };println!("{}", circle.to_string());
}

实现fmt::Display trait,它会自动提供 ToString,并且还可以用来打印类型

use std::fmt;struct Circle {radius: i32
}impl fmt::Display for Circle {fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {write!(f, "Circle of radius {}", self.radius)}
}fn main() {let circle = Circle { radius: 6 };println!("{}", circle.to_string());
}

解析字符串为数字

  • 用 parse 函数
    只要对目标类型实现了 FromStr trait,就可以用 parse 把字符串转换成目标类型

  • “涡轮鱼” 语法(turbo fish,<>)

fn main() {let parsed: i32 = "5".parse().unwrap();let turbo_parsed = "10".parse::<i32>().unwrap();let sum = parsed + turbo_parsed;println!{"Sum: {:?}", sum};
}

总结

From和Info看着都用于构造,只不过From需要显式构造,Info有点半隐

附录

空错误类型

type Error = () 表示一个简单的空错误类型,称为“单元类型”/“单元错误”
() 空括号类型定义为 Error 的别名,来表示错误类型,不包含有用信息,只表示有错误发生。

Rust 内置了一个 Result<T, E> 枚举类型,用于处理可能发生错误的操作。
在这种情况下,类型别名 Error 可以被用作 Result<T, E> 枚举类型中的错误类型 E 的别名,表示可能出现的错误不需要包含详细的错误信息。

在 Rust 中,() 表示一个空元组类型,因此一个空错误类型可以表示为一个空元组类型的别名。

// 定义了一个名称为 `Result` 的新类型别名
// 这个新类型在 `std::result::Result<T, E>` 类型的基础上重新声明
type Result<T> = std::result::Result<T, Error>;fn process_data(data: &str) -> Result<usize> {if data.len() > 10 {Ok(data.len())} else {// 返回空错误Err(())}
}
http://www.hkea.cn/news/726705/

相关文章:

  • 一物一码二维码生成系统最好用的系统优化软件
  • 如何在大网站做外链镇江网站建站
  • 杭州网站建设公司导航短视频营销案例
  • 昆明做网站建设有哪些长尾关键词排名工具
  • 一女被多男做的视频网站网站seo系统
  • 网站建设 青海网站建设找哪家好
  • win7 网站配置优化方案官网电子版
  • 广州seo优化公司排名浙江seo博客
  • 全网推广的方式有哪些抖音seo推荐算法
  • 网站开发开源架构抖音营销软件
  • 自己做的网站能放到网上么青岛seo经理
  • 营业推广策划方案邵阳网站seo
  • 手机网站横向切换kol合作推广
  • 专门做超市海报的网站宁波seo咨询
  • 仿网站上的焦点图在线看seo网站
  • 做网站的业务员艾滋病阻断药有哪些
  • web集团网站建设广告投放平台有哪些
  • 大连做网站建设广告资源对接平台
  • 做网站怎么写工作日志泉州网站seo公司
  • wordpress外链站内打开搜索引擎是什么意思啊
  • 做论坛网站需要什么备案新站seo优化快速上排名
  • 动漫网站html百度网盘搜索
  • 怎么看一个网站什么语言做的宝鸡seo培训
  • 数据库网站建设公司他达拉非片
  • 英文商城网站建设搜索引擎营销的特点
  • 易优建站系统图片百度搜索
  • 网站开发不用框架web网站设计
  • 技能网站建设项目需求武汉网络推广外包公司
  • 安卓市场下载手机版优化网站排名技巧
  • 建设网站平台哪个好互联网营销外包推广