Struct core::ops::RangeInclusive  1.26.0[−][src]
pub struct RangeInclusive<Idx> { /* fields omitted */ }Expand description
范围包括 (start..=end) 的上下边界。
RangeInclusive start..=end 包含 x >= start 和 x <= end 的所有值。除非 start <= end,否则为空。
这个迭代器是 fused,但是迭代完成后 start 和 end 的特定值是未指定的,除了 .is_empty() 之外,一旦不再产生值,就会返回 true。
Examples
start..=end 语法是 RangeInclusive:
assert_eq!((3..=5), std::ops::RangeInclusive::new(3, 5));
assert_eq!(3 + 4 + 5, (3..=5).sum());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   ]);
assert_eq!(arr[1..  ], [   1, 2, 3, 4]);
assert_eq!(arr[1.. 3], [   1, 2      ]);
assert_eq!(arr[1..=3], [   1, 2, 3   ]); // 这是 `RangeInclusive`Implementations
返回范围的下限 (包括下限)。
当使用包含范围进行迭代时,在迭代结束后未指定 start() 和 end() 的值。
若要确定包含范围是否为空,请使用 is_empty() 方法而不是比较 start() > end()。
Note: 范围迭代到穷竭之后,此方法返回的值是不确定的。
Examples
assert_eq!((3..=5).start(), &3);返回范围的上限 (包括上限)。
当使用包含范围进行迭代时,在迭代结束后未指定 start() 和 end() 的值。
若要确定包含范围是否为空,请使用 is_empty() 方法而不是比较 start() > end()。
Note: 范围迭代到穷竭之后,此方法返回的值是不确定的。
Examples
assert_eq!((3..=5).end(), &5);1.35.0[src]pub fn contains<U>(&self, item: &U) -> bool where
    Idx: PartialOrd<U>,
    U: ?Sized + PartialOrd<Idx>, 
pub fn contains<U>(&self, item: &U) -> bool where
    Idx: PartialOrd<U>,
    U: ?Sized + PartialOrd<Idx>, 
如果范围中包含 item,则返回 true。
Examples
assert!(!(3..=5).contains(&2));
assert!( (3..=5).contains(&3));
assert!( (3..=5).contains(&4));
assert!( (3..=5).contains(&5));
assert!(!(3..=5).contains(&6));
assert!( (3..=3).contains(&3));
assert!(!(3..=2).contains(&3));
assert!( (0.0..=1.0).contains(&1.0));
assert!(!(0.0..=1.0).contains(&f32::NAN));
assert!(!(0.0..=f32::NAN).contains(&0.0));
assert!(!(f32::NAN..=1.0).contains(&1.0));迭代完成后,此方法总是返回 false:
let mut r = 3..=5;
assert!(r.contains(&3) && r.contains(&5));
for _ in r.by_ref() {}
// 此处未指定精确的字段值
assert!(!r.contains(&3) && !r.contains(&5));如果范围不包含任何项,则返回 true。
Examples
assert!(!(3..=5).is_empty());
assert!(!(3..=3).is_empty());
assert!( (3..=2).is_empty());如果任何一方都无法比拟,则范围为空:
assert!(!(3.0..=5.0).is_empty());
assert!( (3.0..=f32::NAN).is_empty());
assert!( (f32::NAN..=5.0).is_empty());迭代完成后,此方法返回 true:
let mut r = 3..=5;
for _ in r.by_ref() {}
// 此处未指定精确的字段值
assert!(r.is_empty());Trait Implementations
fn clone(&self) -> RangeInclusive<Idx>ⓘNotable traits for RangeInclusive<A>impl<A: Step> Iterator for RangeInclusive<A>    type Item = A;
fn clone(&self) -> RangeInclusive<Idx>ⓘNotable traits for RangeInclusive<A>impl<A: Step> Iterator for RangeInclusive<A>    type Item = A;
impl<A: Step> Iterator for RangeInclusive<A>    type Item = A;返回值的副本。 Read more
从 source 执行复制分配。 Read more
这是 Iterator::try_fold() 的反向版本:它从迭代器的后面开始接收元素。 Read more
一种迭代器方法,从后面开始,将迭代器的元素减少为单个最终值。 Read more
type Item = A
type Item = A
被迭代的元素的类型。
一个迭代器方法,它只要成功返回就应用函数,并产生单个最终值。 Read more
通过应用操作将每个元素 fold 到一个累加器中,返回最终结果。 Read more
🔬 This is a nightly-only experimental API. (iter_advance_by #77404)
recently added
通过 n 元素使迭代器前进。 Read more
创建一个从同一点开始的迭代器,但在每次迭代时以给定的数量逐步执行。 Read more
接受两个迭代器,并依次在两个迭代器上创建一个新的迭代器。 Read more
将两个迭代器压缩为成对的单个迭代器。 Read more
fn intersperse(self, separator: Self::Item) -> Intersperse<Self>ⓘNotable traits for Intersperse<I>impl<I> Iterator for Intersperse<I> where
    I: Iterator,
    I::Item: Clone,     type Item = I::Item; where
    Self: Sized,
    Self::Item: Clone, 
fn intersperse(self, separator: Self::Item) -> Intersperse<Self>ⓘNotable traits for Intersperse<I>impl<I> Iterator for Intersperse<I> where
    I: Iterator,
    I::Item: Clone,     type Item = I::Item; where
    Self: Sized,
    Self::Item: Clone, 
impl<I> Iterator for Intersperse<I> where
    I: Iterator,
    I::Item: Clone,     type Item = I::Item;🔬 This is a nightly-only experimental API. (iter_intersperse #79524)
recently added
创建一个新的迭代器,该迭代器将 separator 的副本放置在原始迭代器的相邻项之间。 Read more
fn intersperse_with<G>(self, separator: G) -> IntersperseWith<Self, G>ⓘNotable traits for IntersperseWith<I, G>impl<I, G> Iterator for IntersperseWith<I, G> where
    I: Iterator,
    G: FnMut() -> I::Item,     type Item = I::Item; where
    Self: Sized,
    G: FnMut() -> Self::Item, 
fn intersperse_with<G>(self, separator: G) -> IntersperseWith<Self, G>ⓘNotable traits for IntersperseWith<I, G>impl<I, G> Iterator for IntersperseWith<I, G> where
    I: Iterator,
    G: FnMut() -> I::Item,     type Item = I::Item; where
    Self: Sized,
    G: FnMut() -> Self::Item, 
impl<I, G> Iterator for IntersperseWith<I, G> where
    I: Iterator,
    G: FnMut() -> I::Item,     type Item = I::Item;🔬 This is a nightly-only experimental API. (iter_intersperse #79524)
recently added
创建一个新的迭代器,该迭代器将 separator 生成的项放在原始迭代器的相邻项之间。 Read more
获取一个闭包并创建一个迭代器,该迭代器在每个元素上调用该闭包。 Read more
在迭代器的每个元素上调用一个闭包。 Read more
创建一个迭代器,该迭代器使用闭包确定是否应产生元素。 Read more
创建一个同时过滤和映射的迭代器。 Read more
创建一个迭代器,该迭代器给出当前迭代次数以及下一个值。 Read more
创建一个迭代器,该迭代器根据谓词产生元素。 Read more
创建一个迭代器,该迭代器均基于谓词和映射生成元素。 Read more
创建一个跳过前 n 个元素的迭代器。 Read more
创建一个迭代器,它产生第一个 n 元素,如果底层迭代器提前结束,则产生更少的元素。 Read more
创建一个迭代器,其工作方式类似于 map,但它会将嵌套的结构展平。 Read more
创建一个可简化嵌套结构体的迭代器。 Read more
对迭代器的每个元素执行某些操作,将值传递给它。 Read more
将迭代器转换为集合。 Read more
消耗一个迭代器,从中创建两个集合。 Read more
fn partition_in_place<'a, T: 'a, P>(self, predicate: P) -> usize where
    Self: Sized + DoubleEndedIterator<Item = &'a mut T>,
    P: FnMut(&T) -> bool, 
fn partition_in_place<'a, T: 'a, P>(self, predicate: P) -> usize where
    Self: Sized + DoubleEndedIterator<Item = &'a mut T>,
    P: FnMut(&T) -> bool, 
🔬 This is a nightly-only experimental API. (iter_partition_in_place #62543)
new API
根据给定的谓词,对迭代器的元素进行就地重新排序,以使所有返回 true 的元素都在所有返回 false 的元素之前。
返回找到的 true 元素的数量。 Read more
🔬 This is a nightly-only experimental API. (iter_is_partitioned #62544)
new API
检查此迭代器的元素是否根据给定的谓词进行了分区,以便所有返回 true 的元素都在所有返回 false 的元素之前。 Read more
一个迭代器方法,该方法将一个容易犯错的函数应用于迭代器中的每个项,在第一个错误处停止并返回该错误。 Read more
通过重复应用缩减操作,将元素缩减为一个。 Read more
测试迭代器的每个元素是否与谓词匹配。 Read more
测试迭代器的任何元素是否与谓词匹配。 Read more
搜索满足谓词的迭代器的元素。 Read more
将函数应用于迭代器的元素,并返回第一个非 None 的结果。 Read more
🔬 This is a nightly-only experimental API. (try_find #63178)
new API
将函数应用于迭代器的元素,并返回第一个为 true 的结果或第一个错误。 Read more
在迭代器中搜索元素,并返回其索引。 Read more
1.0.0[src]fn rposition<P>(&mut self, predicate: P) -> Option<usize> where
    P: FnMut(Self::Item) -> bool,
    Self: Sized + ExactSizeIterator + DoubleEndedIterator, 
fn rposition<P>(&mut self, predicate: P) -> Option<usize> where
    P: FnMut(Self::Item) -> bool,
    Self: Sized + ExactSizeIterator + DoubleEndedIterator, 
从右侧搜索迭代器中的元素,并返回其索引。 Read more
返回给出指定函数最大值的元素。 Read more
返回给出相对于指定比较函数的最大值的元素。 Read more
返回给出指定函数中最小值的元素。 Read more
返回给出相对于指定比较函数的最小值的元素。 Read more
反转迭代器的方向。 Read more
将成对的迭代器转换为一对容器。 Read more
创建一个迭代器,该迭代器将复制其所有元素。 Read more
创建一个迭代器,该迭代器将克隆所有元素。 Read more
不断重复的迭代器。 Read more
遍历整个迭代器,将所有元素相乘 Read more
1.5.0[src]fn partial_cmp<I>(self, other: I) -> Option<Ordering> where
    I: IntoIterator,
    Self::Item: PartialOrd<I::Item>,
    Self: Sized, 
fn partial_cmp<I>(self, other: I) -> Option<Ordering> where
    I: IntoIterator,
    Self::Item: PartialOrd<I::Item>,
    Self: Sized, 
1.5.0[src]fn lt<I>(self, other: I) -> bool where
    I: IntoIterator,
    Self::Item: PartialOrd<I::Item>,
    Self: Sized, 
fn lt<I>(self, other: I) -> bool where
    I: IntoIterator,
    Self::Item: PartialOrd<I::Item>,
    Self: Sized, 
1.5.0[src]fn le<I>(self, other: I) -> bool where
    I: IntoIterator,
    Self::Item: PartialOrd<I::Item>,
    Self: Sized, 
fn le<I>(self, other: I) -> bool where
    I: IntoIterator,
    Self::Item: PartialOrd<I::Item>,
    Self: Sized, 
1.5.0[src]fn gt<I>(self, other: I) -> bool where
    I: IntoIterator,
    Self::Item: PartialOrd<I::Item>,
    Self: Sized, 
fn gt<I>(self, other: I) -> bool where
    I: IntoIterator,
    Self::Item: PartialOrd<I::Item>,
    Self: Sized, 
1.5.0[src]fn ge<I>(self, other: I) -> bool where
    I: IntoIterator,
    Self::Item: PartialOrd<I::Item>,
    Self: Sized, 
fn ge<I>(self, other: I) -> bool where
    I: IntoIterator,
    Self::Item: PartialOrd<I::Item>,
    Self: Sized, 
🔬 This is a nightly-only experimental API. (is_sorted #53485)
new API
检查此迭代器的元素是否使用给定的比较器函数进行排序。 Read more
fn is_sorted_by_key<F, K>(self, f: F) -> bool where
    Self: Sized,
    F: FnMut(Self::Item) -> K,
    K: PartialOrd, 
fn is_sorted_by_key<F, K>(self, f: F) -> bool where
    Self: Sized,
    F: FnMut(Self::Item) -> K,
    K: PartialOrd, 
🔬 This is a nightly-only experimental API. (is_sorted #53485)
new API
检查此迭代器的元素是否使用给定的键提取函数进行排序。 Read more
此方法测试 self 和 other 值是否相等,并由 == 使用。 Read more
此方法测试 !=。
slice_index_methods)返回此位置输出的共享引用,而不执行任何边界检查。
即使未使用所得的引用,使用越界索引或悬垂的 slice 指针调用此方法也是 [undefined 行为]。 Read more
slice_index_methods)返回此位置输出的变量引用,而不执行任何边界检查。
即使未使用所得的引用,使用越界索引或悬垂的 slice 指针调用此方法也是 [undefined 行为]。 Read more
slice_index_methods)返回此位置输出的共享引用,如果越界则会触发 panic。 Read more
使用语法 &self[begin ..= end] 或 &mut self[begin ..= end] 实现子字符串切片。
从字节范围 [begin, end] 返回给定字符串的切片。等效于 &self [begin .. end + 1] 或 &mut self[begin .. end + 1],除非 end 具有 usize 的最大值。
此运算为 O(1)。
Panics
如果 begin 没有指向字符的起始字节偏移量 (由 is_char_boundary 定义),如果 end 没有指向字符的结束字节偏移量 (end + 1 是起始字节偏移量或等于 len),如果 begin > end,或者如果 end >= len,就会出现 panics。
slice_index_methods)返回此位置输出的共享引用,而不执行任何边界检查。
即使未使用所得的引用,使用越界索引或悬垂的 slice 指针调用此方法也是 [undefined 行为]。 Read more
slice_index_methods)返回此位置输出的变量引用,而不执行任何边界检查。
即使未使用所得的引用,使用越界索引或悬垂的 slice 指针调用此方法也是 [undefined 行为]。 Read more
slice_index_methods)返回此位置输出的共享引用,如果越界则会触发 panic。 Read more