![](/img/trans.png)
[英]How do I add a signed integer to an unsigned integer in Rust, checking for unsigned overflow?
[英]How do I return a flag on integer overflow in Rust?
Swift 有 integer 个溢出算术函数,返回一个标志是否溢出。 我们在 Rust 有同样的东西吗?
从 Rust 1.7.0 开始,在整数类型上定义了overflowing_<operation>(rhs)
。
overflowing_add
的示例:
计算
self
+rhs
返回一个加法元组以及一个指示是否会发生算术溢出的布尔值。 如果发生溢出,则返回包装的值。
例子:
use std::i64;
assert_eq!(5i64.overflowing_add(2), (7, false));
assert_eq!(i64::MAX.overflowing_add(1), (i64::MIN, true));
( 操场)
正如您所注意到的,这有一些内在函数,但这些是unsafe
的并且使用起来有些烦人。
在 Rust 1.0 之前,标准库以CheckedAdd
、 CheckedSub
、 CheckedMul
和CheckedDiv
的形式提供了检测 4 种算术运算溢出的包装器。
从 Rust 1.0 开始,这些特征不再存在,每个数字类型只有固有的方法,例如i32::checked_add
。
但是,这些只是检测溢出而不返回溢出结果:
fn main() {
println!("{:?}", 5u16.checked_add(65530u16));
println!("{:?}", 6u16.checked_add(65530u16));
}
( 操场)
印刷:
Some(65535)
None
Rust 具有整数算术内在函数,例如add_with_overflow
。
pub unsafe extern "rust-intrinsic" fn add_with_overflow<T>(
x: T,
y: T
) -> (T, bool)
包装操作返回的值等于数学上正确的结果模值的范围:
fn main() { { let s=500_u16.wrapping_mul(500); println!("{}", s); } }
在这种情况下
s=53392 // (500*500) module 2^16 =53392
溢出操作返回一个元组(result, overflowed)
,result 是函数的包装版本将如上返回, overflowed
是一个布尔值,指示是否发生溢出。 您可以将此布尔值用作标志:
fn main() { { // because u8 0 to 2^8 –1 (0 to 255) let s=255_u8.overflowing_add(2); // {:?} is used to print a value that implements Debug trait println!("{:?}", s); // s= (1, true) } }
你可以在这里测试代码: https ://play.rust-lang.org/
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.