@@ -691,41 +691,6 @@ impl<T> [T] {
691
691
Chunks { v : self , chunk_size : chunk_size }
692
692
}
693
693
694
- /// Returns an iterator over `chunk_size` elements of the slice at a
695
- /// time. The chunks are slices and do not overlap. If `chunk_size` does
696
- /// not divide the length of the slice, then the last up to `chunk_size-1`
697
- /// elements will be omitted.
698
- ///
699
- /// Due to each chunk having exactly `chunk_size` elements, the compiler
700
- /// can often optimize the resulting code better than in the case of
701
- /// [`chunks`].
702
- ///
703
- /// # Panics
704
- ///
705
- /// Panics if `chunk_size` is 0.
706
- ///
707
- /// # Examples
708
- ///
709
- /// ```
710
- /// #![feature(exact_chunks)]
711
- ///
712
- /// let slice = ['l', 'o', 'r', 'e', 'm'];
713
- /// let mut iter = slice.exact_chunks(2);
714
- /// assert_eq!(iter.next().unwrap(), &['l', 'o']);
715
- /// assert_eq!(iter.next().unwrap(), &['r', 'e']);
716
- /// assert!(iter.next().is_none());
717
- /// ```
718
- ///
719
- /// [`chunks`]: #method.chunks
720
- #[ unstable( feature = "exact_chunks" , issue = "47115" ) ]
721
- #[ inline]
722
- pub fn exact_chunks ( & self , chunk_size : usize ) -> ExactChunks < T > {
723
- assert ! ( chunk_size != 0 ) ;
724
- let rem = self . len ( ) % chunk_size;
725
- let len = self . len ( ) - rem;
726
- ExactChunks { v : & self [ ..len] , chunk_size : chunk_size}
727
- }
728
-
729
694
/// Returns an iterator over `chunk_size` elements of the slice at a time.
730
695
/// The chunks are mutable slices, and do not overlap. If `chunk_size` does
731
696
/// not divide the length of the slice, then the last chunk will not
@@ -761,6 +726,41 @@ impl<T> [T] {
761
726
ChunksMut { v : self , chunk_size : chunk_size }
762
727
}
763
728
729
+ /// Returns an iterator over `chunk_size` elements of the slice at a
730
+ /// time. The chunks are slices and do not overlap. If `chunk_size` does
731
+ /// not divide the length of the slice, then the last up to `chunk_size-1`
732
+ /// elements will be omitted.
733
+ ///
734
+ /// Due to each chunk having exactly `chunk_size` elements, the compiler
735
+ /// can often optimize the resulting code better than in the case of
736
+ /// [`chunks`].
737
+ ///
738
+ /// # Panics
739
+ ///
740
+ /// Panics if `chunk_size` is 0.
741
+ ///
742
+ /// # Examples
743
+ ///
744
+ /// ```
745
+ /// #![feature(exact_chunks)]
746
+ ///
747
+ /// let slice = ['l', 'o', 'r', 'e', 'm'];
748
+ /// let mut iter = slice.exact_chunks(2);
749
+ /// assert_eq!(iter.next().unwrap(), &['l', 'o']);
750
+ /// assert_eq!(iter.next().unwrap(), &['r', 'e']);
751
+ /// assert!(iter.next().is_none());
752
+ /// ```
753
+ ///
754
+ /// [`chunks`]: #method.chunks
755
+ #[ unstable( feature = "exact_chunks" , issue = "47115" ) ]
756
+ #[ inline]
757
+ pub fn exact_chunks ( & self , chunk_size : usize ) -> ExactChunks < T > {
758
+ assert ! ( chunk_size != 0 ) ;
759
+ let rem = self . len ( ) % chunk_size;
760
+ let len = self . len ( ) - rem;
761
+ ExactChunks { v : & self [ ..len] , chunk_size : chunk_size}
762
+ }
763
+
764
764
/// Returns an iterator over `chunk_size` elements of the slice at a time.
765
765
/// The chunks are mutable slices, and do not overlap. If `chunk_size` does
766
766
/// not divide the length of the slice, then the last up to `chunk_size-1`
0 commit comments