当前位置: 首页>>代码示例 >>用法及示例精选 >>正文


Rust RangeToInclusive用法及代码示例


本文简要介绍rust语言中 Struct std::ops::RangeToInclusive 的用法。

用法

pub struct RangeToInclusive<Idx> {
    pub end: Idx,
}

仅包含在上方 (..=end) 的范围。

RangeToInclusive ..=end 包含所有带有 x <= end 的值。它不能用作 Iterator ,因为它没有起点。

例子

..=end 语法是 RangeToInclusive

assert_eq!((..=5), std::ops::RangeToInclusive{ end: 5 });

它没有 IntoIterator 实现,因此您不能直接在for 循环中使用它。这不会编译:

// error[E0277]: the trait bound `std::ops::RangeToInclusive<{integer}>:
// std::iter::Iterator` is not satisfied
for i in ..=5 {
    // ...
}

当用作 slicing index 时,RangeToInclusive 生成所有数组元素的切片,直到并包括 end 指示的索引。

let arr = [0, 1, 2, 3, 4];
assert_eq!(arr[ ..  ], [0, 1, 2, 3, 4]);
assert_eq!(arr[ .. 3], [0, 1, 2      ]);
assert_eq!(arr[ ..=3], [0, 1, 2, 3   ]); // This is a `RangeToInclusive`
assert_eq!(arr[1..  ], [   1, 2, 3, 4]);
assert_eq!(arr[1.. 3], [   1, 2      ]);
assert_eq!(arr[1..=3], [   1, 2, 3   ]);

字段

end: Idx

范围的上限(含)

相关用法


注:本文由纯净天空筛选整理自rust-lang.org大神的英文原创作品 Struct std::ops::RangeToInclusive。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。