Movatterモバイル変換


[0]ホーム

URL:


str

Primitive Typestr 

1.0.0
Expand description

String slices.

See also thestd::str module.

Thestr type, also called a ‘string slice’, is the most primitive stringtype. It is usually seen in its borrowed form,&str. It is also the typeof string literals,&'static str.

§Basic Usage

String literals are string slices:

lethello_world ="Hello, World!";

Here we have declared a string slice initialized with a string literal.String literals have a static lifetime, which means the stringhello_worldis guaranteed to be valid for the duration of the entire program.We can explicitly specifyhello_world’s lifetime as well:

lethello_world:&'staticstr ="Hello, world!";

§Representation

A&str is made up of two components: a pointer to some bytes, and alength. You can look at these with theas_ptr andlen methods:

usestd::slice;usestd::str;letstory ="Once upon a time...";letptr = story.as_ptr();letlen = story.len();// story has nineteen bytesassert_eq!(19, len);// We can re-build a str out of ptr and len. This is all unsafe because// we are responsible for making sure the two components are valid:lets =unsafe{// First, we build a &[u8]...letslice = slice::from_raw_parts(ptr, len);// ... and then convert that slice into a string slicestr::from_utf8(slice)};assert_eq!(s,Ok(story));

Note: This example shows the internals of&str.unsafe should not beused to get a string slice under normal circumstances. Useas_strinstead.

§Invariant

Rust libraries may assume that string slices are always valid UTF-8.

Constructing a non-UTF-8 string slice is not immediate undefined behavior, but any functioncalled on a string slice may assume that it is valid UTF-8, which means that a non-UTF-8 stringslice can lead to undefined behavior down the road.

Implementations§

Source§

implstr

1.0.0 (const: 1.39.0) ·Source

pub const fnlen(&self) ->usize

Returns the length ofself.

This length is in bytes, notchars or graphemes. In other words,it might not be what a human considers the length of the string.

§Examples
letlen ="foo".len();assert_eq!(3, len);assert_eq!("ƒoo".len(),4);// fancy f!assert_eq!("ƒoo".chars().count(),3);
1.0.0 (const: 1.39.0) ·Source

pub const fnis_empty(&self) ->bool

Returnstrue ifself has a length of zero bytes.

§Examples
lets ="";assert!(s.is_empty());lets ="not empty";assert!(!s.is_empty());
1.87.0 (const: 1.87.0) ·Source

pub const fnfrom_utf8(v: &[u8]) ->Result<&str,Utf8Error>

Converts a slice of bytes to a string slice.

A string slice (&str) is made of bytes (u8), and a byte slice(&[u8]) is made of bytes, so this function converts betweenthe two. Not all byte slices are valid string slices, however:&str requiresthat it is valid UTF-8.from_utf8() checks to ensure that the bytes are validUTF-8, and then does the conversion.

If you are sure that the byte slice is valid UTF-8, and you don’t want toincur the overhead of the validity check, there is an unsafe version ofthis function,from_utf8_unchecked, which has the samebehavior but skips the check.

If you need aString instead of a&str, considerString::from_utf8.

Because you can stack-allocate a[u8; N], and you can take a&[u8] of it, this function is one way to have astack-allocated string. There is an example of this in theexamples section below.

§Errors

ReturnsErr if the slice is not UTF-8 with a description as to why theprovided slice is not UTF-8.

§Examples

Basic usage:

// some bytes, in a vectorletsparkle_heart =vec![240,159,146,150];// We can use the ? (try) operator to check if the bytes are validletsparkle_heart = str::from_utf8(&sparkle_heart)?;assert_eq!("💖", sparkle_heart);

Incorrect bytes:

// some invalid bytes, in a vectorletsparkle_heart =vec![0,159,146,150];assert!(str::from_utf8(&sparkle_heart).is_err());

See the docs forUtf8Error for more details on the kinds oferrors that can be returned.

A “stack allocated string”:

// some bytes, in a stack-allocated arrayletsparkle_heart = [240,159,146,150];// We know these bytes are valid, so just use `unwrap()`.letsparkle_heart:&str = str::from_utf8(&sparkle_heart).unwrap();assert_eq!("💖", sparkle_heart);
1.87.0 (const: 1.87.0) ·Source

pub const fnfrom_utf8_mut(v: &mut [u8]) ->Result<&mutstr,Utf8Error>

Converts a mutable slice of bytes to a mutable string slice.

§Examples

Basic usage:

// "Hello, Rust!" as a mutable vectorletmuthellorust =vec![72,101,108,108,111,44,32,82,117,115,116,33];// As we know these bytes are valid, we can use `unwrap()`letoutstr = str::from_utf8_mut(&muthellorust).unwrap();assert_eq!("Hello, Rust!", outstr);

Incorrect bytes:

// Some invalid bytes in a mutable vectorletmutinvalid =vec![128,223];assert!(str::from_utf8_mut(&mutinvalid).is_err());

See the docs forUtf8Error for more details on the kinds oferrors that can be returned.

1.87.0 (const: 1.87.0) ·Source

pub const unsafe fnfrom_utf8_unchecked(v: &[u8]) -> &str

Converts a slice of bytes to a string slice without checkingthat the string contains valid UTF-8.

See the safe version,from_utf8, for more information.

§Safety

The bytes passed in must be valid UTF-8.

§Examples

Basic usage:

// some bytes, in a vectorletsparkle_heart =vec![240,159,146,150];letsparkle_heart =unsafe{    str::from_utf8_unchecked(&sparkle_heart)};assert_eq!("💖", sparkle_heart);
1.87.0 (const: 1.87.0) ·Source

pub const unsafe fnfrom_utf8_unchecked_mut(v: &mut [u8]) -> &mutstr

Converts a slice of bytes to a string slice without checkingthat the string contains valid UTF-8; mutable version.

See the immutable version,from_utf8_unchecked() for documentation and safety requirements.

§Examples

Basic usage:

letmutheart =vec![240,159,146,150];letheart =unsafe{ str::from_utf8_unchecked_mut(&mutheart) };assert_eq!("💖", heart);
1.9.0 (const: 1.86.0) ·Source

pub const fnis_char_boundary(&self, index:usize) ->bool

Checks thatindex-th byte is the first byte in a UTF-8 code pointsequence or the end of the string.

The start and end of the string (whenindex == self.len()) areconsidered to be boundaries.

Returnsfalse ifindex is greater thanself.len().

§Examples
lets ="Löwe 老虎 Léopard";assert!(s.is_char_boundary(0));// start of `老`assert!(s.is_char_boundary(6));assert!(s.is_char_boundary(s.len()));// second byte of `ö`assert!(!s.is_char_boundary(2));// third byte of `老`assert!(!s.is_char_boundary(8));
1.91.0 (const: 1.91.0) ·Source

pub const fnfloor_char_boundary(&self, index:usize) ->usize

Finds the closestx not exceedingindex whereis_char_boundary(x) istrue.

This method can help you truncate a string so that it’s still valid UTF-8, but doesn’texceed a given number of bytes. Note that this is done purely at the character leveland can still visually split graphemes, even though the underlying characters aren’tsplit. For example, the emoji 🧑‍🔬 (scientist) could be split so that the string onlyincludes 🧑 (person) instead.

§Examples
lets ="❤️🧡💛💚💙💜";assert_eq!(s.len(),26);assert!(!s.is_char_boundary(13));letclosest = s.floor_char_boundary(13);assert_eq!(closest,10);assert_eq!(&s[..closest],"❤️🧡");
1.91.0 (const: 1.91.0) ·Source

pub const fnceil_char_boundary(&self, index:usize) ->usize

Finds the closestx not belowindex whereis_char_boundary(x) istrue.

Ifindex is greater than the length of the string, this returns the length of the string.

This method is the natural complement tofloor_char_boundary. See that methodfor more details.

§Examples
lets ="❤️🧡💛💚💙💜";assert_eq!(s.len(),26);assert!(!s.is_char_boundary(13));letclosest = s.ceil_char_boundary(13);assert_eq!(closest,14);assert_eq!(&s[..closest],"❤️🧡💛");
1.0.0 (const: 1.39.0) ·Source

pub const fnas_bytes(&self) -> &[u8]

Converts a string slice to a byte slice. To convert the byte slice backinto a string slice, use thefrom_utf8 function.

§Examples
letbytes ="bors".as_bytes();assert_eq!(b"bors", bytes);
1.20.0 (const: 1.83.0) ·Source

pub const unsafe fnas_bytes_mut(&mut self) -> &mut [u8]

Converts a mutable string slice to a mutable byte slice.

§Safety

The caller must ensure that the content of the slice is valid UTF-8before the borrow ends and the underlyingstr is used.

Use of astr whose contents are not valid UTF-8 is undefined behavior.

§Examples

Basic usage:

letmuts = String::from("Hello");letbytes =unsafe{ s.as_bytes_mut() };assert_eq!(b"Hello", bytes);

Mutability:

letmuts = String::from("🗻∈🌏");unsafe{letbytes = s.as_bytes_mut();    bytes[0] =0xF0;    bytes[1] =0x9F;    bytes[2] =0x8D;    bytes[3] =0x94;}assert_eq!("🍔∈🌏", s);
1.0.0 (const: 1.32.0) ·Source

pub const fnas_ptr(&self) ->*constu8

Converts a string slice to a raw pointer.

As string slices are a slice of bytes, the raw pointer points to au8. This pointer will be pointing to the first byte of the stringslice.

The caller must ensure that the returned pointer is never written to.If you need to mutate the contents of the string slice, useas_mut_ptr.

§Examples
lets ="Hello";letptr = s.as_ptr();
1.36.0 (const: 1.83.0) ·Source

pub const fnas_mut_ptr(&mut self) ->*mutu8

Converts a mutable string slice to a raw pointer.

As string slices are a slice of bytes, the raw pointer points to au8. This pointer will be pointing to the first byte of the stringslice.

It is your responsibility to make sure that the string slice only getsmodified in a way that it remains valid UTF-8.

1.20.0 (const:unstable) ·Source

pub fnget<I>(&self, i: I) ->Option<&<I asSliceIndex<str>>::Output>
where I:SliceIndex<str>,

Returns a subslice ofstr.

This is the non-panicking alternative to indexing thestr. ReturnsNone whenever equivalent indexing operation would panic.

§Examples
letv = String::from("🗻∈🌏");assert_eq!(Some("🗻"), v.get(0..4));// indices not on UTF-8 sequence boundariesassert!(v.get(1..).is_none());assert!(v.get(..8).is_none());// out of boundsassert!(v.get(..42).is_none());
1.20.0 (const:unstable) ·Source

pub fnget_mut<I>( &mut self, i: I,) ->Option<&mut <I asSliceIndex<str>>::Output>
where I:SliceIndex<str>,

Returns a mutable subslice ofstr.

This is the non-panicking alternative to indexing thestr. ReturnsNone whenever equivalent indexing operation would panic.

§Examples
letmutv = String::from("hello");// correct lengthassert!(v.get_mut(0..5).is_some());// out of boundsassert!(v.get_mut(..42).is_none());assert_eq!(Some("he"), v.get_mut(0..2).map(|v|&*v));assert_eq!("hello", v);{lets = v.get_mut(0..2);lets = s.map(|s| {        s.make_ascii_uppercase();&*s    });assert_eq!(Some("HE"), s);}assert_eq!("HEllo", v);
1.20.0 ·Source

pub unsafe fnget_unchecked<I>(&self, i: I) -> &<I asSliceIndex<str>>::Output
where I:SliceIndex<str>,

Returns an unchecked subslice ofstr.

This is the unchecked alternative to indexing thestr.

§Safety

Callers of this function are responsible that these preconditions aresatisfied:

  • The starting index must not exceed the ending index;
  • Indexes must be within bounds of the original slice;
  • Indexes must lie on UTF-8 sequence boundaries.

Failing that, the returned string slice may reference invalid memory orviolate the invariants communicated by thestr type.

§Examples
letv ="🗻∈🌏";unsafe{assert_eq!("🗻", v.get_unchecked(0..4));assert_eq!("∈", v.get_unchecked(4..7));assert_eq!("🌏", v.get_unchecked(7..11));}
1.20.0 ·Source

pub unsafe fnget_unchecked_mut<I>( &mut self, i: I,) -> &mut <I asSliceIndex<str>>::Output
where I:SliceIndex<str>,

Returns a mutable, unchecked subslice ofstr.

This is the unchecked alternative to indexing thestr.

§Safety

Callers of this function are responsible that these preconditions aresatisfied:

  • The starting index must not exceed the ending index;
  • Indexes must be within bounds of the original slice;
  • Indexes must lie on UTF-8 sequence boundaries.

Failing that, the returned string slice may reference invalid memory orviolate the invariants communicated by thestr type.

§Examples
letmutv = String::from("🗻∈🌏");unsafe{assert_eq!("🗻", v.get_unchecked_mut(0..4));assert_eq!("∈", v.get_unchecked_mut(4..7));assert_eq!("🌏", v.get_unchecked_mut(7..11));}
1.0.0 ·Source

pub unsafe fnslice_unchecked(&self, begin:usize, end:usize) -> &str

👎Deprecated since 1.29.0: useget_unchecked(begin..end) instead

Creates a string slice from another string slice, bypassing safetychecks.

This is generally not recommended, use with caution! For a safealternative seestr andIndex.

This new slice goes frombegin toend, includingbegin butexcludingend.

To get a mutable string slice instead, see theslice_mut_unchecked method.

§Safety

Callers of this function are responsible that three preconditions aresatisfied:

  • begin must not exceedend.
  • begin andend must be byte positions within the string slice.
  • begin andend must lie on UTF-8 sequence boundaries.
§Examples
lets ="Löwe 老虎 Léopard";unsafe{assert_eq!("Löwe 老虎 Léopard", s.slice_unchecked(0,21));}lets ="Hello, world!";unsafe{assert_eq!("world", s.slice_unchecked(7,12));}
1.5.0 ·Source

pub unsafe fnslice_mut_unchecked( &mut self, begin:usize, end:usize,) -> &mutstr

👎Deprecated since 1.29.0: useget_unchecked_mut(begin..end) instead

Creates a string slice from another string slice, bypassing safetychecks.

This is generally not recommended, use with caution! For a safealternative seestr andIndexMut.

This new slice goes frombegin toend, includingbegin butexcludingend.

To get an immutable string slice instead, see theslice_unchecked method.

§Safety

Callers of this function are responsible that three preconditions aresatisfied:

  • begin must not exceedend.
  • begin andend must be byte positions within the string slice.
  • begin andend must lie on UTF-8 sequence boundaries.
1.4.0 (const: 1.86.0) ·Source

pub const fnsplit_at(&self, mid:usize) -> (&str, &str)

Divides one string slice into two at an index.

The argument,mid, should be a byte offset from the start of thestring. It must also be on the boundary of a UTF-8 code point.

The two slices returned go from the start of the string slice tomid,and frommid to the end of the string slice.

To get mutable string slices instead, see thesplit_at_mutmethod.

§Panics

Panics ifmid is not on a UTF-8 code point boundary, or if it is pastthe end of the last code point of the string slice. For a non-panickingalternative seesplit_at_checked.

§Examples
lets ="Per Martin-Löf";let(first, last) = s.split_at(3);assert_eq!("Per", first);assert_eq!(" Martin-Löf", last);
1.4.0 (const: 1.86.0) ·Source

pub const fnsplit_at_mut(&mut self, mid:usize) -> (&mutstr, &mutstr)

Divides one mutable string slice into two at an index.

The argument,mid, should be a byte offset from the start of thestring. It must also be on the boundary of a UTF-8 code point.

The two slices returned go from the start of the string slice tomid,and frommid to the end of the string slice.

To get immutable string slices instead, see thesplit_at method.

§Panics

Panics ifmid is not on a UTF-8 code point boundary, or if it is pastthe end of the last code point of the string slice. For a non-panickingalternative seesplit_at_mut_checked.

§Examples
letmuts ="Per Martin-Löf".to_string();{let(first, last) = s.split_at_mut(3);    first.make_ascii_uppercase();assert_eq!("PER", first);assert_eq!(" Martin-Löf", last);}assert_eq!("PER Martin-Löf", s);
1.80.0 (const: 1.86.0) ·Source

pub const fnsplit_at_checked(&self, mid:usize) ->Option<(&str, &str)>

Divides one string slice into two at an index.

The argument,mid, should be a valid byte offset from the start of thestring. It must also be on the boundary of a UTF-8 code point. Themethod returnsNone if that’s not the case.

The two slices returned go from the start of the string slice tomid,and frommid to the end of the string slice.

To get mutable string slices instead, see thesplit_at_mut_checkedmethod.

§Examples
lets ="Per Martin-Löf";let(first, last) = s.split_at_checked(3).unwrap();assert_eq!("Per", first);assert_eq!(" Martin-Löf", last);assert_eq!(None, s.split_at_checked(13));// Inside “ö”assert_eq!(None, s.split_at_checked(16));// Beyond the string length
1.80.0 (const: 1.86.0) ·Source

pub const fnsplit_at_mut_checked( &mut self, mid:usize,) ->Option<(&mutstr, &mutstr)>

Divides one mutable string slice into two at an index.

The argument,mid, should be a valid byte offset from the start of thestring. It must also be on the boundary of a UTF-8 code point. Themethod returnsNone if that’s not the case.

The two slices returned go from the start of the string slice tomid,and frommid to the end of the string slice.

To get immutable string slices instead, see thesplit_at_checked method.

§Examples
letmuts ="Per Martin-Löf".to_string();if letSome((first, last)) = s.split_at_mut_checked(3) {    first.make_ascii_uppercase();assert_eq!("PER", first);assert_eq!(" Martin-Löf", last);}assert_eq!("PER Martin-Löf", s);assert_eq!(None, s.split_at_mut_checked(13));// Inside “ö”assert_eq!(None, s.split_at_mut_checked(16));// Beyond the string length
1.0.0 ·Source

pub fnchars(&self) ->Chars<'_>

Returns an iterator over thechars of a string slice.

As a string slice consists of valid UTF-8, we can iterate through astring slice bychar. This method returns such an iterator.

It’s important to remember thatchar represents a Unicode ScalarValue, and might not match your idea of what a ‘character’ is. Iterationover grapheme clusters may be what you actually want. This functionalityis not provided by Rust’s standard library, check crates.io instead.

§Examples

Basic usage:

letword ="goodbye";letcount = word.chars().count();assert_eq!(7, count);letmutchars = word.chars();assert_eq!(Some('g'), chars.next());assert_eq!(Some('o'), chars.next());assert_eq!(Some('o'), chars.next());assert_eq!(Some('d'), chars.next());assert_eq!(Some('b'), chars.next());assert_eq!(Some('y'), chars.next());assert_eq!(Some('e'), chars.next());assert_eq!(None, chars.next());

Remember,chars might not match your intuition about characters:

lety ="y̆";letmutchars = y.chars();assert_eq!(Some('y'), chars.next());// not 'y̆'assert_eq!(Some('\u{0306}'), chars.next());assert_eq!(None, chars.next());
1.0.0 ·Source

pub fnchar_indices(&self) ->CharIndices<'_>

Returns an iterator over thechars of a string slice, and theirpositions.

As a string slice consists of valid UTF-8, we can iterate through astring slice bychar. This method returns an iterator of boththesechars, as well as their byte positions.

The iterator yields tuples. The position is first, thechar issecond.

§Examples

Basic usage:

letword ="goodbye";letcount = word.char_indices().count();assert_eq!(7, count);letmutchar_indices = word.char_indices();assert_eq!(Some((0,'g')), char_indices.next());assert_eq!(Some((1,'o')), char_indices.next());assert_eq!(Some((2,'o')), char_indices.next());assert_eq!(Some((3,'d')), char_indices.next());assert_eq!(Some((4,'b')), char_indices.next());assert_eq!(Some((5,'y')), char_indices.next());assert_eq!(Some((6,'e')), char_indices.next());assert_eq!(None, char_indices.next());

Remember,chars might not match your intuition about characters:

letyes ="y̆es";letmutchar_indices = yes.char_indices();assert_eq!(Some((0,'y')), char_indices.next());// not (0, 'y̆')assert_eq!(Some((1,'\u{0306}')), char_indices.next());// note the 3 here - the previous character took up two bytesassert_eq!(Some((3,'e')), char_indices.next());assert_eq!(Some((4,'s')), char_indices.next());assert_eq!(None, char_indices.next());
1.0.0 ·Source

pub fnbytes(&self) ->Bytes<'_>

Returns an iterator over the bytes of a string slice.

As a string slice consists of a sequence of bytes, we can iteratethrough a string slice by byte. This method returns such an iterator.

§Examples
letmutbytes ="bors".bytes();assert_eq!(Some(b'b'), bytes.next());assert_eq!(Some(b'o'), bytes.next());assert_eq!(Some(b'r'), bytes.next());assert_eq!(Some(b's'), bytes.next());assert_eq!(None, bytes.next());
1.1.0 ·Source

pub fnsplit_whitespace(&self) ->SplitWhitespace<'_>

Splits a string slice by whitespace.

The iterator returned will return string slices that are sub-slices ofthe original string slice, separated by any amount of whitespace.

‘Whitespace’ is defined according to the terms of the Unicode DerivedCore PropertyWhite_Space. If you only want to split on ASCII whitespaceinstead, usesplit_ascii_whitespace.

§Examples

Basic usage:

letmutiter ="A few words".split_whitespace();assert_eq!(Some("A"), iter.next());assert_eq!(Some("few"), iter.next());assert_eq!(Some("words"), iter.next());assert_eq!(None, iter.next());

All kinds of whitespace are considered:

letmutiter =" Mary   had\ta\u{2009}little  \n\t lamb".split_whitespace();assert_eq!(Some("Mary"), iter.next());assert_eq!(Some("had"), iter.next());assert_eq!(Some("a"), iter.next());assert_eq!(Some("little"), iter.next());assert_eq!(Some("lamb"), iter.next());assert_eq!(None, iter.next());

If the string is empty or all whitespace, the iterator yields no string slices:

assert_eq!("".split_whitespace().next(),None);assert_eq!("   ".split_whitespace().next(),None);
1.34.0 ·Source

pub fnsplit_ascii_whitespace(&self) ->SplitAsciiWhitespace<'_>

Splits a string slice by ASCII whitespace.

The iterator returned will return string slices that are sub-slices ofthe original string slice, separated by any amount of ASCII whitespace.

This uses the same definition aschar::is_ascii_whitespace.To split by UnicodeWhitespace instead, usesplit_whitespace.

§Examples

Basic usage:

letmutiter ="A few words".split_ascii_whitespace();assert_eq!(Some("A"), iter.next());assert_eq!(Some("few"), iter.next());assert_eq!(Some("words"), iter.next());assert_eq!(None, iter.next());

Various kinds of ASCII whitespace are considered(seechar::is_ascii_whitespace):

letmutiter =" Mary   had\ta little  \n\t lamb".split_ascii_whitespace();assert_eq!(Some("Mary"), iter.next());assert_eq!(Some("had"), iter.next());assert_eq!(Some("a"), iter.next());assert_eq!(Some("little"), iter.next());assert_eq!(Some("lamb"), iter.next());assert_eq!(None, iter.next());

If the string is empty or all ASCII whitespace, the iterator yields no string slices:

assert_eq!("".split_ascii_whitespace().next(),None);assert_eq!("   ".split_ascii_whitespace().next(),None);
1.0.0 ·Source

pub fnlines(&self) ->Lines<'_>

Returns an iterator over the lines of a string, as string slices.

Lines are split at line endings that are either newlines (\n) orsequences of a carriage return followed by a line feed (\r\n).

Line terminators are not included in the lines returned by the iterator.

Note that any carriage return (\r) not immediately followed by aline feed (\n) does not split a line. These carriage returns arethereby included in the produced lines.

The final line ending is optional. A string that ends with a final lineending will return the same lines as an otherwise identical stringwithout a final line ending.

An empty string returns an empty iterator.

§Examples

Basic usage:

lettext ="foo\r\nbar\n\nbaz\r";letmutlines = text.lines();assert_eq!(Some("foo"), lines.next());assert_eq!(Some("bar"), lines.next());assert_eq!(Some(""), lines.next());// Trailing carriage return is included in the last lineassert_eq!(Some("baz\r"), lines.next());assert_eq!(None, lines.next());

The final line does not require any ending:

lettext ="foo\nbar\n\r\nbaz";letmutlines = text.lines();assert_eq!(Some("foo"), lines.next());assert_eq!(Some("bar"), lines.next());assert_eq!(Some(""), lines.next());assert_eq!(Some("baz"), lines.next());assert_eq!(None, lines.next());

An empty string returns an empty iterator:

lettext ="";letmutlines = text.lines();assert_eq!(lines.next(),None);
1.0.0 ·Source

pub fnlines_any(&self) ->LinesAny<'_>

👎Deprecated since 1.4.0: use lines() instead now

Returns an iterator over the lines of a string.

1.8.0 ·Source

pub fnencode_utf16(&self) ->EncodeUtf16<'_>

Returns an iterator ofu16 over the string encodedas native endian UTF-16 (without byte-order mark).

§Examples
lettext ="Zażółć gęślą jaźń";letutf8_len = text.len();letutf16_len = text.encode_utf16().count();assert!(utf16_len <= utf8_len);
1.0.0 ·Source

pub fncontains<P>(&self, pat: P) ->bool
where P:Pattern,

Returnstrue if the given pattern matches a sub-slice ofthis string slice.

Returnsfalse if it does not.

Thepattern can be a&str,char, a slice ofchars, or afunction or closure that determines if a character matches.

§Examples
letbananas ="bananas";assert!(bananas.contains("nana"));assert!(!bananas.contains("apples"));
1.0.0 ·Source

pub fnstarts_with<P>(&self, pat: P) ->bool
where P:Pattern,

Returnstrue if the given pattern matches a prefix of thisstring slice.

Returnsfalse if it does not.

Thepattern can be a&str, in which case this function will return true ifthe&str is a prefix of this string slice.

Thepattern can also be achar, a slice ofchars, or afunction or closure that determines if a character matches.These will only be checked against the first character of this string slice.Look at the second example below regarding behavior for slices ofchars.

§Examples
letbananas ="bananas";assert!(bananas.starts_with("bana"));assert!(!bananas.starts_with("nana"));
letbananas ="bananas";// Note that both of these assert successfully.assert!(bananas.starts_with(&['b','a','n','a']));assert!(bananas.starts_with(&['a','b','c','d']));
1.0.0 ·Source

pub fnends_with<P>(&self, pat: P) ->bool
where P:Pattern, <P asPattern>::Searcher<'a>: for<'a>ReverseSearcher<'a>,

Returnstrue if the given pattern matches a suffix of thisstring slice.

Returnsfalse if it does not.

Thepattern can be a&str,char, a slice ofchars, or afunction or closure that determines if a character matches.

§Examples
letbananas ="bananas";assert!(bananas.ends_with("anas"));assert!(!bananas.ends_with("nana"));
1.0.0 ·Source

pub fnfind<P>(&self, pat: P) ->Option<usize>
where P:Pattern,

Returns the byte index of the first character of this string slice thatmatches the pattern.

ReturnsNone if the pattern doesn’t match.

Thepattern can be a&str,char, a slice ofchars, or afunction or closure that determines if a character matches.

§Examples

Simple patterns:

lets ="Löwe 老虎 Léopard Gepardi";assert_eq!(s.find('L'),Some(0));assert_eq!(s.find('é'),Some(14));assert_eq!(s.find("pard"),Some(17));

More complex patterns using point-free style and closures:

lets ="Löwe 老虎 Léopard";assert_eq!(s.find(char::is_whitespace),Some(5));assert_eq!(s.find(char::is_lowercase),Some(1));assert_eq!(s.find(|c: char| c.is_whitespace() || c.is_lowercase()),Some(1));assert_eq!(s.find(|c: char| (c <'o') && (c >'a')),Some(4));

Not finding the pattern:

lets ="Löwe 老虎 Léopard";letx:&[_] =&['1','2'];assert_eq!(s.find(x),None);
1.0.0 ·Source

pub fnrfind<P>(&self, pat: P) ->Option<usize>
where P:Pattern, <P asPattern>::Searcher<'a>: for<'a>ReverseSearcher<'a>,

Returns the byte index for the first character of the last match of the pattern inthis string slice.

ReturnsNone if the pattern doesn’t match.

Thepattern can be a&str,char, a slice ofchars, or afunction or closure that determines if a character matches.

§Examples

Simple patterns:

lets ="Löwe 老虎 Léopard Gepardi";assert_eq!(s.rfind('L'),Some(13));assert_eq!(s.rfind('é'),Some(14));assert_eq!(s.rfind("pard"),Some(24));

More complex patterns with closures:

lets ="Löwe 老虎 Léopard";assert_eq!(s.rfind(char::is_whitespace),Some(12));assert_eq!(s.rfind(char::is_lowercase),Some(20));

Not finding the pattern:

lets ="Löwe 老虎 Léopard";letx:&[_] =&['1','2'];assert_eq!(s.rfind(x),None);
1.0.0 ·Source

pub fnsplit<P>(&self, pat: P) ->Split<'_, P>
where P:Pattern,

Returns an iterator over substrings of this string slice, separated bycharacters matched by a pattern.

Thepattern can be a&str,char, a slice ofchars, or afunction or closure that determines if a character matches.

If there are no matches the full string slice is returned as the onlyitem in the iterator.

§Iterator behavior

The returned iterator will be aDoubleEndedIterator if the patternallows a reverse search and forward/reverse search yields the sameelements. This is true for, e.g.,char, but not for&str.

If the pattern allows a reverse search but its results might differfrom a forward search, thersplit method can be used.

§Examples

Simple patterns:

letv: Vec<&str> ="Mary had a little lamb".split(' ').collect();assert_eq!(v, ["Mary","had","a","little","lamb"]);letv: Vec<&str> ="".split('X').collect();assert_eq!(v, [""]);letv: Vec<&str> ="lionXXtigerXleopard".split('X').collect();assert_eq!(v, ["lion","","tiger","leopard"]);letv: Vec<&str> ="lion::tiger::leopard".split("::").collect();assert_eq!(v, ["lion","tiger","leopard"]);letv: Vec<&str> ="AABBCC".split("DD").collect();assert_eq!(v, ["AABBCC"]);letv: Vec<&str> ="abc1def2ghi".split(char::is_numeric).collect();assert_eq!(v, ["abc","def","ghi"]);letv: Vec<&str> ="lionXtigerXleopard".split(char::is_uppercase).collect();assert_eq!(v, ["lion","tiger","leopard"]);

If the pattern is a slice of chars, split on each occurrence of any of the characters:

letv: Vec<&str> ="2020-11-03 23:59".split(&['-',' ',':','@'][..]).collect();assert_eq!(v, ["2020","11","03","23","59"]);

A more complex pattern, using a closure:

letv: Vec<&str> ="abc1defXghi".split(|c| c =='1'|| c =='X').collect();assert_eq!(v, ["abc","def","ghi"]);

If a string contains multiple contiguous separators, you will end upwith empty strings in the output:

letx ="||||a||b|c".to_string();letd: Vec<_> = x.split('|').collect();assert_eq!(d,&["","","","","a","","b","c"]);

Contiguous separators are separated by the empty string.

letx ="(///)".to_string();letd: Vec<_> = x.split('/').collect();assert_eq!(d,&["(","","",")"]);

Separators at the start or end of a string are neighboredby empty strings.

letd: Vec<_> ="010".split("0").collect();assert_eq!(d,&["","1",""]);

When the empty string is used as a separator, it separatesevery character in the string, along with the beginningand end of the string.

letf: Vec<_> ="rust".split("").collect();assert_eq!(f,&["","r","u","s","t",""]);

Contiguous separators can lead to possibly surprising behaviorwhen whitespace is used as the separator. This code is correct:

letx ="    a  b c".to_string();letd: Vec<_> = x.split(' ').collect();assert_eq!(d,&["","","","","a","","b","c"]);

It doesnot give you:

assert_eq!(d,&["a","b","c"]);

Usesplit_whitespace for this behavior.

1.51.0 ·Source

pub fnsplit_inclusive<P>(&self, pat: P) ->SplitInclusive<'_, P>
where P:Pattern,

Returns an iterator over substrings of this string slice, separated bycharacters matched by a pattern.

Differs from the iterator produced bysplit in thatsplit_inclusiveleaves the matched part as the terminator of the substring.

Thepattern can be a&str,char, a slice ofchars, or afunction or closure that determines if a character matches.

§Examples
letv: Vec<&str> ="Mary had a little lamb\nlittle lamb\nlittle lamb.".split_inclusive('\n').collect();assert_eq!(v, ["Mary had a little lamb\n","little lamb\n","little lamb."]);

If the last element of the string is matched,that element will be considered the terminator of the preceding substring.That substring will be the last item returned by the iterator.

letv: Vec<&str> ="Mary had a little lamb\nlittle lamb\nlittle lamb.\n".split_inclusive('\n').collect();assert_eq!(v, ["Mary had a little lamb\n","little lamb\n","little lamb.\n"]);
1.0.0 ·Source

pub fnrsplit<P>(&self, pat: P) ->RSplit<'_, P>
where P:Pattern, <P asPattern>::Searcher<'a>: for<'a>ReverseSearcher<'a>,

Returns an iterator over substrings of the given string slice, separatedby characters matched by a pattern and yielded in reverse order.

Thepattern can be a&str,char, a slice ofchars, or afunction or closure that determines if a character matches.

§Iterator behavior

The returned iterator requires that the pattern supports a reversesearch, and it will be aDoubleEndedIterator if a forward/reversesearch yields the same elements.

For iterating from the front, thesplit method can be used.

§Examples

Simple patterns:

letv: Vec<&str> ="Mary had a little lamb".rsplit(' ').collect();assert_eq!(v, ["lamb","little","a","had","Mary"]);letv: Vec<&str> ="".rsplit('X').collect();assert_eq!(v, [""]);letv: Vec<&str> ="lionXXtigerXleopard".rsplit('X').collect();assert_eq!(v, ["leopard","tiger","","lion"]);letv: Vec<&str> ="lion::tiger::leopard".rsplit("::").collect();assert_eq!(v, ["leopard","tiger","lion"]);

A more complex pattern, using a closure:

letv: Vec<&str> ="abc1defXghi".rsplit(|c| c =='1'|| c =='X').collect();assert_eq!(v, ["ghi","def","abc"]);
1.0.0 ·Source

pub fnsplit_terminator<P>(&self, pat: P) ->SplitTerminator<'_, P>
where P:Pattern,

Returns an iterator over substrings of the given string slice, separatedby characters matched by a pattern.

Thepattern can be a&str,char, a slice ofchars, or afunction or closure that determines if a character matches.

Equivalent tosplit, except that the trailing substringis skipped if empty.

This method can be used for string data that isterminated,rather thanseparated by a pattern.

§Iterator behavior

The returned iterator will be aDoubleEndedIterator if the patternallows a reverse search and forward/reverse search yields the sameelements. This is true for, e.g.,char, but not for&str.

If the pattern allows a reverse search but its results might differfrom a forward search, thersplit_terminator method can be used.

§Examples
letv: Vec<&str> ="A.B.".split_terminator('.').collect();assert_eq!(v, ["A","B"]);letv: Vec<&str> ="A..B..".split_terminator(".").collect();assert_eq!(v, ["A","","B",""]);letv: Vec<&str> ="A.B:C.D".split_terminator(&['.',':'][..]).collect();assert_eq!(v, ["A","B","C","D"]);
1.0.0 ·Source

pub fnrsplit_terminator<P>(&self, pat: P) ->RSplitTerminator<'_, P>
where P:Pattern, <P asPattern>::Searcher<'a>: for<'a>ReverseSearcher<'a>,

Returns an iterator over substrings ofself, separated by charactersmatched by a pattern and yielded in reverse order.

Thepattern can be a&str,char, a slice ofchars, or afunction or closure that determines if a character matches.

Equivalent tosplit, except that the trailing substring isskipped if empty.

This method can be used for string data that isterminated,rather thanseparated by a pattern.

§Iterator behavior

The returned iterator requires that the pattern supports areverse search, and it will be double ended if a forward/reversesearch yields the same elements.

For iterating from the front, thesplit_terminator method can beused.

§Examples
letv: Vec<&str> ="A.B.".rsplit_terminator('.').collect();assert_eq!(v, ["B","A"]);letv: Vec<&str> ="A..B..".rsplit_terminator(".").collect();assert_eq!(v, ["","B","","A"]);letv: Vec<&str> ="A.B:C.D".rsplit_terminator(&['.',':'][..]).collect();assert_eq!(v, ["D","C","B","A"]);
1.0.0 ·Source

pub fnsplitn<P>(&self, n:usize, pat: P) ->SplitN<'_, P>
where P:Pattern,

Returns an iterator over substrings of the given string slice, separatedby a pattern, restricted to returning at mostn items.

Ifn substrings are returned, the last substring (thenth substring)will contain the remainder of the string.

Thepattern can be a&str,char, a slice ofchars, or afunction or closure that determines if a character matches.

§Iterator behavior

The returned iterator will not be double ended, because it isnot efficient to support.

If the pattern allows a reverse search, thersplitn method can beused.

§Examples

Simple patterns:

letv: Vec<&str> ="Mary had a little lambda".splitn(3,' ').collect();assert_eq!(v, ["Mary","had","a little lambda"]);letv: Vec<&str> ="lionXXtigerXleopard".splitn(3,"X").collect();assert_eq!(v, ["lion","","tigerXleopard"]);letv: Vec<&str> ="abcXdef".splitn(1,'X').collect();assert_eq!(v, ["abcXdef"]);letv: Vec<&str> ="".splitn(1,'X').collect();assert_eq!(v, [""]);

A more complex pattern, using a closure:

letv: Vec<&str> ="abc1defXghi".splitn(2, |c| c =='1'|| c =='X').collect();assert_eq!(v, ["abc","defXghi"]);
1.0.0 ·Source

pub fnrsplitn<P>(&self, n:usize, pat: P) ->RSplitN<'_, P>
where P:Pattern, <P asPattern>::Searcher<'a>: for<'a>ReverseSearcher<'a>,

Returns an iterator over substrings of this string slice, separated by apattern, starting from the end of the string, restricted to returning atmostn items.

Ifn substrings are returned, the last substring (thenth substring)will contain the remainder of the string.

Thepattern can be a&str,char, a slice ofchars, or afunction or closure that determines if a character matches.

§Iterator behavior

The returned iterator will not be double ended, because it is notefficient to support.

For splitting from the front, thesplitn method can be used.

§Examples

Simple patterns:

letv: Vec<&str> ="Mary had a little lamb".rsplitn(3,' ').collect();assert_eq!(v, ["lamb","little","Mary had a"]);letv: Vec<&str> ="lionXXtigerXleopard".rsplitn(3,'X').collect();assert_eq!(v, ["leopard","tiger","lionX"]);letv: Vec<&str> ="lion::tiger::leopard".rsplitn(2,"::").collect();assert_eq!(v, ["leopard","lion::tiger"]);

A more complex pattern, using a closure:

letv: Vec<&str> ="abc1defXghi".rsplitn(2, |c| c =='1'|| c =='X').collect();assert_eq!(v, ["ghi","abc1def"]);
1.52.0 ·Source

pub fnsplit_once<P>(&self, delimiter: P) ->Option<(&str, &str)>
where P:Pattern,

Splits the string on the first occurrence of the specified delimiter andreturns prefix before delimiter and suffix after delimiter.

§Examples
assert_eq!("cfg".split_once('='),None);assert_eq!("cfg=".split_once('='),Some(("cfg","")));assert_eq!("cfg=foo".split_once('='),Some(("cfg","foo")));assert_eq!("cfg=foo=bar".split_once('='),Some(("cfg","foo=bar")));
1.52.0 ·Source

pub fnrsplit_once<P>(&self, delimiter: P) ->Option<(&str, &str)>
where P:Pattern, <P asPattern>::Searcher<'a>: for<'a>ReverseSearcher<'a>,

Splits the string on the last occurrence of the specified delimiter andreturns prefix before delimiter and suffix after delimiter.

§Examples
assert_eq!("cfg".rsplit_once('='),None);assert_eq!("cfg=".rsplit_once('='),Some(("cfg","")));assert_eq!("cfg=foo".rsplit_once('='),Some(("cfg","foo")));assert_eq!("cfg=foo=bar".rsplit_once('='),Some(("cfg=foo","bar")));
1.2.0 ·Source

pub fnmatches<P>(&self, pat: P) ->Matches<'_, P>
where P:Pattern,

Returns an iterator over the disjoint matches of a pattern within thegiven string slice.

Thepattern can be a&str,char, a slice ofchars, or afunction or closure that determines if a character matches.

§Iterator behavior

The returned iterator will be aDoubleEndedIterator if the patternallows a reverse search and forward/reverse search yields the sameelements. This is true for, e.g.,char, but not for&str.

If the pattern allows a reverse search but its results might differfrom a forward search, thermatches method can be used.

§Examples
letv: Vec<&str> ="abcXXXabcYYYabc".matches("abc").collect();assert_eq!(v, ["abc","abc","abc"]);letv: Vec<&str> ="1abc2abc3".matches(char::is_numeric).collect();assert_eq!(v, ["1","2","3"]);
1.2.0 ·Source

pub fnrmatches<P>(&self, pat: P) ->RMatches<'_, P>
where P:Pattern, <P asPattern>::Searcher<'a>: for<'a>ReverseSearcher<'a>,

Returns an iterator over the disjoint matches of a pattern within thisstring slice, yielded in reverse order.

Thepattern can be a&str,char, a slice ofchars, or afunction or closure that determines if a character matches.

§Iterator behavior

The returned iterator requires that the pattern supports a reversesearch, and it will be aDoubleEndedIterator if a forward/reversesearch yields the same elements.

For iterating from the front, thematches method can be used.

§Examples
letv: Vec<&str> ="abcXXXabcYYYabc".rmatches("abc").collect();assert_eq!(v, ["abc","abc","abc"]);letv: Vec<&str> ="1abc2abc3".rmatches(char::is_numeric).collect();assert_eq!(v, ["3","2","1"]);
1.5.0 ·Source

pub fnmatch_indices<P>(&self, pat: P) ->MatchIndices<'_, P>
where P:Pattern,

Returns an iterator over the disjoint matches of a pattern within this stringslice as well as the index that the match starts at.

For matches ofpat withinself that overlap, only the indicescorresponding to the first match are returned.

Thepattern can be a&str,char, a slice ofchars, or afunction or closure that determines if a character matches.

§Iterator behavior

The returned iterator will be aDoubleEndedIterator if the patternallows a reverse search and forward/reverse search yields the sameelements. This is true for, e.g.,char, but not for&str.

If the pattern allows a reverse search but its results might differfrom a forward search, thermatch_indices method can be used.

§Examples
letv: Vec<_> ="abcXXXabcYYYabc".match_indices("abc").collect();assert_eq!(v, [(0,"abc"), (6,"abc"), (12,"abc")]);letv: Vec<_> ="1abcabc2".match_indices("abc").collect();assert_eq!(v, [(1,"abc"), (4,"abc")]);letv: Vec<_> ="ababa".match_indices("aba").collect();assert_eq!(v, [(0,"aba")]);// only the first `aba`
1.5.0 ·Source

pub fnrmatch_indices<P>(&self, pat: P) ->RMatchIndices<'_, P>
where P:Pattern, <P asPattern>::Searcher<'a>: for<'a>ReverseSearcher<'a>,

Returns an iterator over the disjoint matches of a pattern withinself,yielded in reverse order along with the index of the match.

For matches ofpat withinself that overlap, only the indicescorresponding to the last match are returned.

Thepattern can be a&str,char, a slice ofchars, or afunction or closure that determines if a character matches.

§Iterator behavior

The returned iterator requires that the pattern supports a reversesearch, and it will be aDoubleEndedIterator if a forward/reversesearch yields the same elements.

For iterating from the front, thematch_indices method can be used.

§Examples
letv: Vec<_> ="abcXXXabcYYYabc".rmatch_indices("abc").collect();assert_eq!(v, [(12,"abc"), (6,"abc"), (0,"abc")]);letv: Vec<_> ="1abcabc2".rmatch_indices("abc").collect();assert_eq!(v, [(4,"abc"), (1,"abc")]);letv: Vec<_> ="ababa".rmatch_indices("aba").collect();assert_eq!(v, [(2,"aba")]);// only the last `aba`
1.0.0 ·Source

pub fntrim(&self) -> &str

Returns a string slice with leading and trailing whitespace removed.

‘Whitespace’ is defined according to the terms of the Unicode DerivedCore PropertyWhite_Space, which includes newlines.

§Examples
lets ="\n Hello\tworld\t\n";assert_eq!("Hello\tworld", s.trim());
1.30.0 ·Source

pub fntrim_start(&self) -> &str

Returns a string slice with leading whitespace removed.

‘Whitespace’ is defined according to the terms of the Unicode DerivedCore PropertyWhite_Space, which includes newlines.

§Text directionality

A string is a sequence of bytes.start in this context means the firstposition of that byte string; for a left-to-right language like English orRussian, this will be left side, and for right-to-left languages likeArabic or Hebrew, this will be the right side.

§Examples

Basic usage:

lets ="\n Hello\tworld\t\n";assert_eq!("Hello\tworld\t\n", s.trim_start());

Directionality:

lets ="  English  ";assert!(Some('E') == s.trim_start().chars().next());lets ="  עברית  ";assert!(Some('ע') == s.trim_start().chars().next());
1.30.0 ·Source

pub fntrim_end(&self) -> &str

Returns a string slice with trailing whitespace removed.

‘Whitespace’ is defined according to the terms of the Unicode DerivedCore PropertyWhite_Space, which includes newlines.

§Text directionality

A string is a sequence of bytes.end in this context means the lastposition of that byte string; for a left-to-right language like English orRussian, this will be right side, and for right-to-left languages likeArabic or Hebrew, this will be the left side.

§Examples

Basic usage:

lets ="\n Hello\tworld\t\n";assert_eq!("\n Hello\tworld", s.trim_end());

Directionality:

lets ="  English  ";assert!(Some('h') == s.trim_end().chars().rev().next());lets ="  עברית  ";assert!(Some('ת') == s.trim_end().chars().rev().next());
1.0.0 ·Source

pub fntrim_left(&self) -> &str

👎Deprecated since 1.33.0: superseded bytrim_start

Returns a string slice with leading whitespace removed.

‘Whitespace’ is defined according to the terms of the Unicode DerivedCore PropertyWhite_Space.

§Text directionality

A string is a sequence of bytes. ‘Left’ in this context means the firstposition of that byte string; for a language like Arabic or Hebrewwhich are ‘right to left’ rather than ‘left to right’, this will betheright side, not the left.

§Examples

Basic usage:

lets =" Hello\tworld\t";assert_eq!("Hello\tworld\t", s.trim_left());

Directionality:

lets ="  English";assert!(Some('E') == s.trim_left().chars().next());lets ="  עברית";assert!(Some('ע') == s.trim_left().chars().next());
1.0.0 ·Source

pub fntrim_right(&self) -> &str

👎Deprecated since 1.33.0: superseded bytrim_end

Returns a string slice with trailing whitespace removed.

‘Whitespace’ is defined according to the terms of the Unicode DerivedCore PropertyWhite_Space.

§Text directionality

A string is a sequence of bytes. ‘Right’ in this context means the lastposition of that byte string; for a language like Arabic or Hebrewwhich are ‘right to left’ rather than ‘left to right’, this will betheleft side, not the right.

§Examples

Basic usage:

lets =" Hello\tworld\t";assert_eq!(" Hello\tworld", s.trim_right());

Directionality:

lets ="English  ";assert!(Some('h') == s.trim_right().chars().rev().next());lets ="עברית  ";assert!(Some('ת') == s.trim_right().chars().rev().next());
1.0.0 ·Source

pub fntrim_matches<P>(&self, pat: P) -> &str
where P:Pattern, <P asPattern>::Searcher<'a>: for<'a>DoubleEndedSearcher<'a>,

Returns a string slice with all prefixes and suffixes that match apattern repeatedly removed.

Thepattern can be achar, a slice ofchars, or a functionor closure that determines if a character matches.

§Examples

Simple patterns:

assert_eq!("11foo1bar11".trim_matches('1'),"foo1bar");assert_eq!("123foo1bar123".trim_matches(char::is_numeric),"foo1bar");letx:&[_] =&['1','2'];assert_eq!("12foo1bar12".trim_matches(x),"foo1bar");

A more complex pattern, using a closure:

assert_eq!("1foo1barXX".trim_matches(|c| c =='1'|| c =='X'),"foo1bar");
1.30.0 ·Source

pub fntrim_start_matches<P>(&self, pat: P) -> &str
where P:Pattern,

Returns a string slice with all prefixes that match a patternrepeatedly removed.

Thepattern can be a&str,char, a slice ofchars, or afunction or closure that determines if a character matches.

§Text directionality

A string is a sequence of bytes.start in this context means the firstposition of that byte string; for a left-to-right language like English orRussian, this will be left side, and for right-to-left languages likeArabic or Hebrew, this will be the right side.

§Examples
assert_eq!("11foo1bar11".trim_start_matches('1'),"foo1bar11");assert_eq!("123foo1bar123".trim_start_matches(char::is_numeric),"foo1bar123");letx:&[_] =&['1','2'];assert_eq!("12foo1bar12".trim_start_matches(x),"foo1bar12");
1.45.0 ·Source

pub fnstrip_prefix<P>(&self, prefix: P) ->Option<&str>
where P:Pattern,

Returns a string slice with the prefix removed.

If the string starts with the patternprefix, returns the substring after the prefix,wrapped inSome. Unliketrim_start_matches, this method removes the prefix exactly once.

If the string does not start withprefix, returnsNone.

Thepattern can be a&str,char, a slice ofchars, or afunction or closure that determines if a character matches.

§Examples
assert_eq!("foo:bar".strip_prefix("foo:"),Some("bar"));assert_eq!("foo:bar".strip_prefix("bar"),None);assert_eq!("foofoo".strip_prefix("foo"),Some("foo"));
1.45.0 ·Source

pub fnstrip_suffix<P>(&self, suffix: P) ->Option<&str>
where P:Pattern, <P asPattern>::Searcher<'a>: for<'a>ReverseSearcher<'a>,

Returns a string slice with the suffix removed.

If the string ends with the patternsuffix, returns the substring before the suffix,wrapped inSome. Unliketrim_end_matches, this method removes the suffix exactly once.

If the string does not end withsuffix, returnsNone.

Thepattern can be a&str,char, a slice ofchars, or afunction or closure that determines if a character matches.

§Examples
assert_eq!("bar:foo".strip_suffix(":foo"),Some("bar"));assert_eq!("bar:foo".strip_suffix("bar"),None);assert_eq!("foofoo".strip_suffix("foo"),Some("foo"));
Source

pub fnstrip_circumfix<P, S>(&self, prefix: P, suffix: S) ->Option<&str>
where P:Pattern, S:Pattern, <S asPattern>::Searcher<'a>: for<'a>ReverseSearcher<'a>,

🔬This is a nightly-only experimental API. (strip_circumfix #147946)

Returns a string slice with the prefix and suffix removed.

If the string starts with the patternprefix and ends with the patternsuffix, returnsthe substring after the prefix and before the suffix, wrapped inSome.Unliketrim_start_matches andtrim_end_matches, this method removes both the prefixand suffix exactly once.

If the string does not start withprefix or does not end withsuffix, returnsNone.

Eachpattern can be a&str,char, a slice ofchars, or afunction or closure that determines if a character matches.

§Examples
#![feature(strip_circumfix)]assert_eq!("bar:hello:foo".strip_circumfix("bar:",":foo"),Some("hello"));assert_eq!("bar:foo".strip_circumfix("foo","foo"),None);assert_eq!("foo:bar;".strip_circumfix("foo:",';'),Some("bar"));
Source

pub fntrim_prefix<P>(&self, prefix: P) -> &str
where P:Pattern,

🔬This is a nightly-only experimental API. (trim_prefix_suffix #142312)

Returns a string slice with the optional prefix removed.

If the string starts with the patternprefix, returns the substring after the prefix.Unlikestrip_prefix, this method always returns&str for easy method chaining,instead of returningOption<&str>.

If the string does not start withprefix, returns the original string unchanged.

Thepattern can be a&str,char, a slice ofchars, or afunction or closure that determines if a character matches.

§Examples
#![feature(trim_prefix_suffix)]// Prefix present - removes itassert_eq!("foo:bar".trim_prefix("foo:"),"bar");assert_eq!("foofoo".trim_prefix("foo"),"foo");// Prefix absent - returns original stringassert_eq!("foo:bar".trim_prefix("bar"),"foo:bar");// Method chaining exampleassert_eq!("<https://example.com/>".trim_prefix('<').trim_suffix('>'),"https://example.com/");
Source

pub fntrim_suffix<P>(&self, suffix: P) -> &str
where P:Pattern, <P asPattern>::Searcher<'a>: for<'a>ReverseSearcher<'a>,

🔬This is a nightly-only experimental API. (trim_prefix_suffix #142312)

Returns a string slice with the optional suffix removed.

If the string ends with the patternsuffix, returns the substring before the suffix.Unlikestrip_suffix, this method always returns&str for easy method chaining,instead of returningOption<&str>.

If the string does not end withsuffix, returns the original string unchanged.

Thepattern can be a&str,char, a slice ofchars, or afunction or closure that determines if a character matches.

§Examples
#![feature(trim_prefix_suffix)]// Suffix present - removes itassert_eq!("bar:foo".trim_suffix(":foo"),"bar");assert_eq!("foofoo".trim_suffix("foo"),"foo");// Suffix absent - returns original stringassert_eq!("bar:foo".trim_suffix("bar"),"bar:foo");// Method chaining exampleassert_eq!("<https://example.com/>".trim_prefix('<').trim_suffix('>'),"https://example.com/");
1.30.0 ·Source

pub fntrim_end_matches<P>(&self, pat: P) -> &str
where P:Pattern, <P asPattern>::Searcher<'a>: for<'a>ReverseSearcher<'a>,

Returns a string slice with all suffixes that match a patternrepeatedly removed.

Thepattern can be a&str,char, a slice ofchars, or afunction or closure that determines if a character matches.

§Text directionality

A string is a sequence of bytes.end in this context means the lastposition of that byte string; for a left-to-right language like English orRussian, this will be right side, and for right-to-left languages likeArabic or Hebrew, this will be the left side.

§Examples

Simple patterns:

assert_eq!("11foo1bar11".trim_end_matches('1'),"11foo1bar");assert_eq!("123foo1bar123".trim_end_matches(char::is_numeric),"123foo1bar");letx:&[_] =&['1','2'];assert_eq!("12foo1bar12".trim_end_matches(x),"12foo1bar");

A more complex pattern, using a closure:

assert_eq!("1fooX".trim_end_matches(|c| c =='1'|| c =='X'),"1foo");
1.0.0 ·Source

pub fntrim_left_matches<P>(&self, pat: P) -> &str
where P:Pattern,

👎Deprecated since 1.33.0: superseded bytrim_start_matches

Returns a string slice with all prefixes that match a patternrepeatedly removed.

Thepattern can be a&str,char, a slice ofchars, or afunction or closure that determines if a character matches.

§Text directionality

A string is a sequence of bytes. ‘Left’ in this context means the firstposition of that byte string; for a language like Arabic or Hebrewwhich are ‘right to left’ rather than ‘left to right’, this will betheright side, not the left.

§Examples
assert_eq!("11foo1bar11".trim_left_matches('1'),"foo1bar11");assert_eq!("123foo1bar123".trim_left_matches(char::is_numeric),"foo1bar123");letx:&[_] =&['1','2'];assert_eq!("12foo1bar12".trim_left_matches(x),"foo1bar12");
1.0.0 ·Source

pub fntrim_right_matches<P>(&self, pat: P) -> &str
where P:Pattern, <P asPattern>::Searcher<'a>: for<'a>ReverseSearcher<'a>,

👎Deprecated since 1.33.0: superseded bytrim_end_matches

Returns a string slice with all suffixes that match a patternrepeatedly removed.

Thepattern can be a&str,char, a slice ofchars, or afunction or closure that determines if a character matches.

§Text directionality

A string is a sequence of bytes. ‘Right’ in this context means the lastposition of that byte string; for a language like Arabic or Hebrewwhich are ‘right to left’ rather than ‘left to right’, this will betheleft side, not the right.

§Examples

Simple patterns:

assert_eq!("11foo1bar11".trim_right_matches('1'),"11foo1bar");assert_eq!("123foo1bar123".trim_right_matches(char::is_numeric),"123foo1bar");letx:&[_] =&['1','2'];assert_eq!("12foo1bar12".trim_right_matches(x),"12foo1bar");

A more complex pattern, using a closure:

assert_eq!("1fooX".trim_right_matches(|c| c =='1'|| c =='X'),"1foo");
1.0.0 ·Source

pub fnparse<F>(&self) ->Result<F, <F asFromStr>::Err>
where F:FromStr,

Parses this string slice into another type.

Becauseparse is so general, it can cause problems with typeinference. As such,parse is one of the few times you’ll seethe syntax affectionately known as the ‘turbofish’:::<>. Thishelps the inference algorithm understand specifically which typeyou’re trying to parse into.

parse can parse into any type that implements theFromStr trait.

§Errors

Will returnErr if it’s not possible to parse this string slice intothe desired type.

§Examples

Basic usage:

letfour: u32 ="4".parse().unwrap();assert_eq!(4, four);

Using the ‘turbofish’ instead of annotatingfour:

letfour ="4".parse::<u32>();assert_eq!(Ok(4), four);

Failing to parse:

letnope ="j".parse::<u32>();assert!(nope.is_err());
1.23.0 (const: 1.74.0) ·Source

pub const fnis_ascii(&self) ->bool

Checks if all characters in this string are within the ASCII range.

An empty string returnstrue.

§Examples
letascii ="hello!\n";letnon_ascii ="Grüße, Jürgen ❤";assert!(ascii.is_ascii());assert!(!non_ascii.is_ascii());
Source

pub const fnas_ascii(&self) ->Option<&[AsciiChar]>

🔬This is a nightly-only experimental API. (ascii_char #110998)

If this string sliceis_ascii, returns it as a sliceofASCII characters, otherwise returnsNone.

Source

pub const unsafe fnas_ascii_unchecked(&self) -> &[AsciiChar]

🔬This is a nightly-only experimental API. (ascii_char #110998)

Converts this string slice into a slice ofASCII characters,without checking whether they are valid.

§Safety

Every character in this string must be ASCII, or else this is UB.

1.23.0 (const: 1.89.0) ·Source

pub const fneq_ignore_ascii_case(&self, other: &str) ->bool

Checks that two strings are an ASCII case-insensitive match.

Same asto_ascii_lowercase(a) == to_ascii_lowercase(b),but without allocating and copying temporaries.

§Examples
assert!("Ferris".eq_ignore_ascii_case("FERRIS"));assert!("Ferrös".eq_ignore_ascii_case("FERRöS"));assert!(!"Ferrös".eq_ignore_ascii_case("FERRÖS"));
1.23.0 (const: 1.84.0) ·Source

pub const fnmake_ascii_uppercase(&mut self)

Converts this string to its ASCII upper case equivalent in-place.

ASCII letters ‘a’ to ‘z’ are mapped to ‘A’ to ‘Z’,but non-ASCII letters are unchanged.

To return a new uppercased value without modifying the existing one, useto_ascii_uppercase().

§Examples
letmuts = String::from("Grüße, Jürgen ❤");s.make_ascii_uppercase();assert_eq!("GRüßE, JüRGEN ❤", s);
1.23.0 (const: 1.84.0) ·Source

pub const fnmake_ascii_lowercase(&mut self)

Converts this string to its ASCII lower case equivalent in-place.

ASCII letters ‘A’ to ‘Z’ are mapped to ‘a’ to ‘z’,but non-ASCII letters are unchanged.

To return a new lowercased value without modifying the existing one, useto_ascii_lowercase().

§Examples
letmuts = String::from("GRÜßE, JÜRGEN ❤");s.make_ascii_lowercase();assert_eq!("grÜße, jÜrgen ❤", s);
1.80.0 (const: 1.80.0) ·Source

pub const fntrim_ascii_start(&self) -> &str

Returns a string slice with leading ASCII whitespace removed.

‘Whitespace’ refers to the definition used byu8::is_ascii_whitespace.

§Examples
assert_eq!(" \t \u{3000}hello world\n".trim_ascii_start(),"\u{3000}hello world\n");assert_eq!("  ".trim_ascii_start(),"");assert_eq!("".trim_ascii_start(),"");
1.80.0 (const: 1.80.0) ·Source

pub const fntrim_ascii_end(&self) -> &str

Returns a string slice with trailing ASCII whitespace removed.

‘Whitespace’ refers to the definition used byu8::is_ascii_whitespace.

§Examples
assert_eq!("\r hello world\u{3000}\n ".trim_ascii_end(),"\r hello world\u{3000}");assert_eq!("  ".trim_ascii_end(),"");assert_eq!("".trim_ascii_end(),"");
1.80.0 (const: 1.80.0) ·Source

pub const fntrim_ascii(&self) -> &str

Returns a string slice with leading and trailing ASCII whitespaceremoved.

‘Whitespace’ refers to the definition used byu8::is_ascii_whitespace.

§Examples
assert_eq!("\r hello world\n ".trim_ascii(),"hello world");assert_eq!("  ".trim_ascii(),"");assert_eq!("".trim_ascii(),"");
1.34.0 ·Source

pub fnescape_debug(&self) ->EscapeDebug<'_>

Returns an iterator that escapes each char inself withchar::escape_debug.

Note: only extended grapheme codepoints that begin the string will beescaped.

§Examples

As an iterator:

forcin"❤\n!".escape_debug() {print!("{c}");}println!();

Usingprintln! directly:

println!("{}","❤\n!".escape_debug());

Both are equivalent to:

println!("❤\\n!");

Usingto_string:

assert_eq!("❤\n!".escape_debug().to_string(),"❤\\n!");
1.34.0 ·Source

pub fnescape_default(&self) ->EscapeDefault<'_>

Returns an iterator that escapes each char inself withchar::escape_default.

§Examples

As an iterator:

forcin"❤\n!".escape_default() {print!("{c}");}println!();

Usingprintln! directly:

println!("{}","❤\n!".escape_default());

Both are equivalent to:

println!("\\u{{2764}}\\n!");

Usingto_string:

assert_eq!("❤\n!".escape_default().to_string(),"\\u{2764}\\n!");
1.34.0 ·Source

pub fnescape_unicode(&self) ->EscapeUnicode<'_>

Returns an iterator that escapes each char inself withchar::escape_unicode.

§Examples

As an iterator:

forcin"❤\n!".escape_unicode() {print!("{c}");}println!();

Usingprintln! directly:

println!("{}","❤\n!".escape_unicode());

Both are equivalent to:

println!("\\u{{2764}}\\u{{a}}\\u{{21}}");

Usingto_string:

assert_eq!("❤\n!".escape_unicode().to_string(),"\\u{2764}\\u{a}\\u{21}");
Source

pub fnsubstr_range(&self, substr: &str) ->Option<Range<usize>>

🔬This is a nightly-only experimental API. (substr_range #126769)

Returns the range that a substring points to.

ReturnsNone ifsubstr does not point withinself.

Unlikestr::find,this does not search through the string.Instead, it uses pointer arithmetic to find where in the stringsubstr is derived from.

This is useful for extendingstr::split and similar methods.

Note that this method may return false positives (typically eitherSome(0..0) orSome(self.len()..self.len())) ifsubstr is azero-lengthstr that points at the beginning or end of another,independent,str.

§Examples
#![feature(substr_range)]letdata ="a, b, b, a";letmutiter = data.split(", ").map(|s| data.substr_range(s).unwrap());assert_eq!(iter.next(),Some(0..1));assert_eq!(iter.next(),Some(3..4));assert_eq!(iter.next(),Some(6..7));assert_eq!(iter.next(),Some(9..10));
Source

pub const fnas_str(&self) -> &str

🔬This is a nightly-only experimental API. (str_as_str #130366)

Returns the same string as a string slice&str.

This method is redundant when used directly on&str, butit helps dereferencing other string-like types to string slices,for example references toBox<str> orArc<str>.

Source§

implstr

Methods for string slices.

1.20.0 ·Source

pub fninto_boxed_bytes(self:Box<str>) ->Box<[u8]>

Converts aBox<str> into aBox<[u8]> without copying or allocating.

§Examples
lets ="this is a string";letboxed_str = s.to_owned().into_boxed_str();letboxed_bytes = boxed_str.into_boxed_bytes();assert_eq!(*boxed_bytes,*s.as_bytes());
1.0.0 ·Source

pub fnreplace<P>(&self, from: P, to: &str) ->String
where P:Pattern,

Replaces all matches of a pattern with another string.

replace creates a newString, and copies the data from this string slice into it.While doing so, it attempts to find matches of a pattern. If it finds any, itreplaces them with the replacement string slice.

§Examples
lets ="this is old";assert_eq!("this is new", s.replace("old","new"));assert_eq!("than an old", s.replace("is","an"));

When the pattern doesn’t match, it returns this string slice asString:

lets ="this is old";assert_eq!(s, s.replace("cookie monster","little lamb"));
1.16.0 ·Source

pub fnreplacen<P>(&self, pat: P, to: &str, count:usize) ->String
where P:Pattern,

Replaces first N matches of a pattern with another string.

replacen creates a newString, and copies the data from this string slice into it.While doing so, it attempts to find matches of a pattern. If it finds any, itreplaces them with the replacement string slice at mostcount times.

§Examples
lets ="foo foo 123 foo";assert_eq!("new new 123 foo", s.replacen("foo","new",2));assert_eq!("faa fao 123 foo", s.replacen('o',"a",3));assert_eq!("foo foo new23 foo", s.replacen(char::is_numeric,"new",1));

When the pattern doesn’t match, it returns this string slice asString:

lets ="this is old";assert_eq!(s, s.replacen("cookie monster","little lamb",10));
1.2.0 ·Source

pub fnto_lowercase(&self) ->String

Returns the lowercase equivalent of this string slice, as a newString.

‘Lowercase’ is defined according to the terms of the Unicode Derived Core PropertyLowercase.

Since some characters can expand into multiple characters when changingthe case, this function returns aString instead of modifying theparameter in-place.

§Examples

Basic usage:

lets ="HELLO";assert_eq!("hello", s.to_lowercase());

A tricky example, with sigma:

letsigma ="Σ";assert_eq!("σ", sigma.to_lowercase());// but at the end of a word, it's ς, not σ:letodysseus ="ὈΔΥΣΣΕΎΣ";assert_eq!("ὀδυσσεύς", odysseus.to_lowercase());

Languages without case are not changed:

letnew_year ="农历新年";assert_eq!(new_year, new_year.to_lowercase());
1.2.0 ·Source

pub fnto_uppercase(&self) ->String

Returns the uppercase equivalent of this string slice, as a newString.

‘Uppercase’ is defined according to the terms of the Unicode Derived Core PropertyUppercase.

Since some characters can expand into multiple characters when changingthe case, this function returns aString instead of modifying theparameter in-place.

§Examples

Basic usage:

lets ="hello";assert_eq!("HELLO", s.to_uppercase());

Scripts without case are not changed:

letnew_year ="农历新年";assert_eq!(new_year, new_year.to_uppercase());

One character can become multiple:

lets ="tschüß";assert_eq!("TSCHÜSS", s.to_uppercase());
1.4.0 ·Source

pub fninto_string(self:Box<str>) ->String

Converts aBox<str> into aString without copying or allocating.

§Examples
letstring = String::from("birthday gift");letboxed_str = string.clone().into_boxed_str();assert_eq!(boxed_str.into_string(), string);
1.16.0 ·Source

pub fnrepeat(&self, n:usize) ->String

Creates a newString by repeating a stringn times.

§Panics

This function will panic if the capacity would overflow.

§Examples

Basic usage:

assert_eq!("abc".repeat(4), String::from("abcabcabcabc"));

A panic upon overflow:

// this will panic at runtimelethuge ="0123456789abcdef".repeat(usize::MAX);
1.23.0 ·Source

pub fnto_ascii_uppercase(&self) ->String

Returns a copy of this string where each character is mapped to itsASCII upper case equivalent.

ASCII letters ‘a’ to ‘z’ are mapped to ‘A’ to ‘Z’,but non-ASCII letters are unchanged.

To uppercase the value in-place, usemake_ascii_uppercase.

To uppercase ASCII characters in addition to non-ASCII characters, useto_uppercase.

§Examples
lets ="Grüße, Jürgen ❤";assert_eq!("GRüßE, JüRGEN ❤", s.to_ascii_uppercase());
1.23.0 ·Source

pub fnto_ascii_lowercase(&self) ->String

Returns a copy of this string where each character is mapped to itsASCII lower case equivalent.

ASCII letters ‘A’ to ‘Z’ are mapped to ‘a’ to ‘z’,but non-ASCII letters are unchanged.

To lowercase the value in-place, usemake_ascii_lowercase.

To lowercase ASCII characters in addition to non-ASCII characters, useto_lowercase.

§Examples
lets ="Grüße, Jürgen ❤";assert_eq!("grüße, jürgen ❤", s.to_ascii_lowercase());

Trait Implementations§

1.14.0 ·Source§

impl<'a>Add<&'astr> forCow<'a,str>

Source§

typeOutput =Cow<'a,str>

The resulting type after applying the+ operator.
Source§

fnadd(self, rhs: &'astr) -> <Cow<'a,str> asAdd<&'astr>>::Output

Performs the+ operation.Read more
1.0.0 ·Source§

implAdd<&str> forString

Implements the+ operator for concatenating two strings.

This consumes theString on the left-hand side and re-uses its buffer (growing it ifnecessary). This is done to avoid allocating a newString and copying the entire contents onevery operation, which would lead toO(n^2) running time when building ann-byte string byrepeated concatenation.

The string on the right-hand side is only borrowed; its contents are copied into the returnedString.

§Examples

Concatenating twoStrings takes the first by value and borrows the second:

leta = String::from("hello");letb = String::from(" world");letc = a +&b;// `a` is moved and can no longer be used here.

If you want to keep using the firstString, you can clone it and append to the clone instead:

leta = String::from("hello");letb = String::from(" world");letc = a.clone() +&b;// `a` is still valid here.

Concatenating&str slices can be done by converting the first to aString:

leta ="hello";letb =" world";letc = a.to_string() + b;
Source§

typeOutput =String

The resulting type after applying the+ operator.
Source§

fnadd(self, other: &str) ->String

Performs the+ operation.Read more
1.14.0 ·Source§

impl<'a>AddAssign<&'astr> forCow<'a,str>

Source§

fnadd_assign(&mut self, rhs: &'astr)

Performs the+= operation.Read more
1.12.0 ·Source§

implAddAssign<&str> forString

Implements the+= operator for appending to aString.

This has the same behavior as thepush_str method.

Source§

fnadd_assign(&mut self, other: &str)

Performs the+= operation.Read more
1.43.0 ·Source§

implAsMut<str> forString

Source§

fnas_mut(&mut self) -> &mutstr

Converts this type into a mutable reference of the (usually inferred) input type.
1.51.0 (const:unstable) ·Source§

implAsMut<str> forstr

Source§

fnas_mut(&mut self) -> &mutstr

Converts this type into a mutable reference of the (usually inferred) input type.
1.0.0 (const:unstable) ·Source§

implAsRef<[u8]> forstr

Source§

fnas_ref(&self) -> &[u8]

Converts this type into a shared reference of the (usually inferred) input type.
Source§

implAsRef<ByteStr> forstr

Source§

fnas_ref(&self) -> &ByteStr

Converts this type into a shared reference of the (usually inferred) input type.
1.0.0 ·Source§

implAsRef<OsStr> forstr

Source§

fnas_ref(&self) -> &OsStr

Converts this type into a shared reference of the (usually inferred) input type.
1.0.0 ·Source§

implAsRef<Path> forstr

Source§

fnas_ref(&self) -> &Path

Converts this type into a shared reference of the (usually inferred) input type.
1.55.0 ·Source§

impl<'a>AsRef<str> forDrain<'a>

Source§

fnas_ref(&self) -> &str

Converts this type into a shared reference of the (usually inferred) input type.
1.0.0 ·Source§

implAsRef<str> forString

Source§

fnas_ref(&self) -> &str

Converts this type into a shared reference of the (usually inferred) input type.
1.0.0 (const:unstable) ·Source§

implAsRef<str> forstr

Source§

fnas_ref(&self) -> &str

Converts this type into a shared reference of the (usually inferred) input type.
1.0.0 ·Source§

implAsciiExt forstr

Source§

typeOwned =String

👎Deprecated since 1.26.0: use inherent methods instead
Container type for copied ASCII characters.
Source§

fnis_ascii(&self) ->bool

👎Deprecated since 1.26.0: use inherent methods instead
Checks if the value is within the ASCII range.Read more
Source§

fnto_ascii_uppercase(&self) -> Self::Owned

👎Deprecated since 1.26.0: use inherent methods instead
Makes a copy of the value in its ASCII upper case equivalent.Read more
Source§

fnto_ascii_lowercase(&self) -> Self::Owned

👎Deprecated since 1.26.0: use inherent methods instead
Makes a copy of the value in its ASCII lower case equivalent.Read more
Source§

fneq_ignore_ascii_case(&self, o: &Self) ->bool

👎Deprecated since 1.26.0: use inherent methods instead
Checks that two values are an ASCII case-insensitive match.Read more
Source§

fnmake_ascii_uppercase(&mut self)

👎Deprecated since 1.26.0: use inherent methods instead
Converts this type to its ASCII upper case equivalent in-place.Read more
Source§

fnmake_ascii_lowercase(&mut self)

👎Deprecated since 1.26.0: use inherent methods instead
Converts this type to its ASCII lower case equivalent in-place.Read more
1.0.0 ·Source§

implBorrow<str> forString

Source§

fnborrow(&self) -> &str

Immutably borrows from an owned value.Read more
1.36.0 ·Source§

implBorrowMut<str> forString

Source§

fnborrow_mut(&mut self) -> &mutstr

Mutably borrows from an owned value.Read more
1.3.0 ·Source§

implClone forBox<str>

Source§

fnclone(&self) ->Box<str>

Returns a duplicate of the value.Read more
1.0.0 ·Source§

fnclone_from(&mut self, source: &Self)

Performs copy-assignment fromsource.Read more
Source§

implCloneToUninit forstr

Source§

unsafe fnclone_to_uninit(&self, dest:*mutu8)

🔬This is a nightly-only experimental API. (clone_to_uninit #126799)
Performs copy-assignment fromself todest.Read more
Source§

impl<S>Concat<str> for[S]
where S:Borrow<str>,

Note:str inConcat<str> is not meaningful here.This type parameter of the trait only exists to enable another impl.

Source§

typeOutput =String

🔬This is a nightly-only experimental API. (slice_concat_trait #27747)
The resulting type after concatenation
Source§

fnconcat(slice: &[S]) ->String

🔬This is a nightly-only experimental API. (slice_concat_trait #27747)
Implementation of[T]::concat
1.0.0 ·Source§

implDebug forstr

Source§

fnfmt(&self, f: &mutFormatter<'_>) ->Result<(),Error>

Formats the value using the given formatter.Read more
1.28.0 (const:unstable) ·Source§

implDefault for &mutstr

Source§

fndefault() -> &mutstr

Creates an empty mutable str

1.0.0 (const:unstable) ·Source§

implDefault for &str

Source§

fndefault() -> &str

Creates an empty str

1.17.0 ·Source§

implDefault forBox<str>

Source§

fndefault() ->Box<str>

Returns the “default value” for a type.Read more
1.0.0 ·Source§

implDisplay forstr

Source§

fnfmt(&self, f: &mutFormatter<'_>) ->Result<(),Error>

Formats the value using the given formatter.Read more
1.0.0 ·Source§

impl<'a>Extend<&'astr> forString

Source§

fnextend<I>(&mut self, iter: I)
where I:IntoIterator<Item = &'astr>,

Extends a collection with the contents of an iterator.Read more
Source§

fnextend_one(&mut self, s: &'astr)

🔬This is a nightly-only experimental API. (extend_one #72631)
Extends a collection with exactly one element.
Source§

fnextend_reserve(&mut self, additional:usize)

🔬This is a nightly-only experimental API. (extend_one #72631)
Reserves capacity in a collection for the given number of additional elements.Read more
1.84.0 ·Source§

implFrom<&mutstr> forArc<str>

Source§

fnfrom(v: &mutstr) ->Arc<str>

Allocates a reference-countedstr and copiesv into it.

§Example
letmutoriginal = String::from("eggplant");letoriginal:&mutstr =&mutoriginal;letshared: Arc<str> = Arc::from(original);assert_eq!("eggplant",&shared[..]);
1.84.0 ·Source§

implFrom<&mutstr> forBox<str>

Source§

fnfrom(s: &mutstr) ->Box<str>

Converts a&mut str into aBox<str>

This conversion allocates on the heapand performs a copy ofs.

§Examples
letmutoriginal = String::from("hello");letoriginal:&mutstr =&mutoriginal;letboxed: Box<str> = Box::from(original);println!("{boxed}");
1.84.0 ·Source§

implFrom<&mutstr> forRc<str>

Source§

fnfrom(v: &mutstr) ->Rc<str>

Allocates a reference-counted string slice and copiesv into it.

§Example
letmutoriginal = String::from("statue");letoriginal:&mutstr =&mutoriginal;letshared: Rc<str> = Rc::from(original);assert_eq!("statue",&shared[..]);
1.44.0 ·Source§

implFrom<&mutstr> forString

Source§

fnfrom(s: &mutstr) ->String

Converts a&mut str into aString.

The result is allocated on the heap.

1.21.0 ·Source§

implFrom<&str> forArc<str>

Source§

fnfrom(v: &str) ->Arc<str>

Allocates a reference-countedstr and copiesv into it.

§Example
letshared: Arc<str> = Arc::from("eggplant");assert_eq!("eggplant",&shared[..]);
1.6.0 ·Source§

impl<'a>From<&str> forBox<dynError + 'a>

Source§

fnfrom(err: &str) ->Box<dynError + 'a>

Converts astr into a box of dynError.

§Examples
usestd::error::Error;leta_str_error ="a str error";leta_boxed_error = Box::<dynError>::from(a_str_error);assert!(size_of::<Box<dynError>>() == size_of_val(&a_boxed_error))
1.0.0 ·Source§

impl<'a>From<&str> forBox<dynError +Send +Sync + 'a>

Source§

fnfrom(err: &str) ->Box<dynError +Send +Sync + 'a>

Converts astr into a box of dynError +Send +Sync.

§Examples
usestd::error::Error;leta_str_error ="a str error";leta_boxed_error = Box::<dynError + Send + Sync>::from(a_str_error);assert!(    size_of::<Box<dynError + Send + Sync>>() == size_of_val(&a_boxed_error))
1.17.0 ·Source§

implFrom<&str> forBox<str>

Source§

fnfrom(s: &str) ->Box<str>

Converts a&str into aBox<str>

This conversion allocates on the heapand performs a copy ofs.

§Examples
letboxed: Box<str> = Box::from("hello");println!("{boxed}");
1.0.0 ·Source§

impl<'a>From<&'astr> forCow<'a,str>

Source§

fnfrom(s: &'astr) ->Cow<'a,str>

Converts a string slice into aBorrowed variant.No heap allocation is performed, and the stringis not copied.

§Example
assert_eq!(Cow::from("eggplant"), Cow::Borrowed("eggplant"));
1.21.0 ·Source§

implFrom<&str> forRc<str>

Source§

fnfrom(v: &str) ->Rc<str>

Allocates a reference-counted string slice and copiesv into it.

§Example
letshared: Rc<str> = Rc::from("statue");assert_eq!("statue",&shared[..]);
1.0.0 ·Source§

implFrom<&str> forString

Source§

fnfrom(s: &str) ->String

Converts a&str into aString.

The result is allocated on the heap.

1.0.0 ·Source§

implFrom<&str> forVec<u8>

Source§

fnfrom(s: &str) ->Vec<u8>

Allocates aVec<u8> and fills it with a UTF-8 string.

§Examples
assert_eq!(Vec::from("123"),vec![b'1',b'2',b'3']);
1.45.0 ·Source§

implFrom<Cow<'_,str>> forBox<str>

Source§

fnfrom(cow:Cow<'_,str>) ->Box<str>

Converts aCow<'_, str> into aBox<str>

Whencow is theCow::Borrowed variant, thisconversion allocates on the heap and copies theunderlyingstr. Otherwise, it will try to reuse the ownedString’s allocation.

§Examples
usestd::borrow::Cow;letunboxed = Cow::Borrowed("hello");letboxed: Box<str> = Box::from(unboxed);println!("{boxed}");
letunboxed = Cow::Owned("hello".to_string());letboxed: Box<str> = Box::from(unboxed);println!("{boxed}");
1.20.0 ·Source§

implFrom<String> forBox<str>

Source§

fnfrom(s:String) ->Box<str>

Converts the givenString to a boxedstr slice that is owned.

§Examples
lets1: String = String::from("hello world");lets2: Box<str> = Box::from(s1);lets3: String = String::from(s2);assert_eq!("hello world", s3)
1.80.0 ·Source§

impl<'a>FromIterator<&'achar> forBox<str>

Source§

fnfrom_iter<T>(iter: T) ->Box<str>
where T:IntoIterator<Item = &'achar>,

Creates a value from an iterator.Read more
1.80.0 ·Source§

impl<'a>FromIterator<&'astr> forBox<str>

Source§

fnfrom_iter<T>(iter: T) ->Box<str>
where T:IntoIterator<Item = &'astr>,

Creates a value from an iterator.Read more
Source§

impl<'a>FromIterator<&'astr> forByteString

Source§

fnfrom_iter<T>(iter: T) ->ByteString
where T:IntoIterator<Item = &'astr>,

Creates a value from an iterator.Read more
1.12.0 ·Source§

impl<'a, 'b>FromIterator<&'bstr> forCow<'a,str>

Source§

fnfrom_iter<I>(it: I) ->Cow<'a,str>
where I:IntoIterator<Item = &'bstr>,

Creates a value from an iterator.Read more
1.0.0 ·Source§

impl<'a>FromIterator<&'astr> forString

Source§

fnfrom_iter<I>(iter: I) ->String
where I:IntoIterator<Item = &'astr>,

Creates a value from an iterator.Read more
1.80.0 ·Source§

impl<A>FromIterator<Box<str, A>> forBox<str>
where A:Allocator,

Source§

fnfrom_iter<T>(iter: T) ->Box<str>
where T:IntoIterator<Item =Box<str, A>>,

Creates a value from an iterator.Read more
1.80.0 ·Source§

impl<'a>FromIterator<Cow<'a,str>> forBox<str>

Source§

fnfrom_iter<T>(iter: T) ->Box<str>
where T:IntoIterator<Item =Cow<'a,str>>,

Creates a value from an iterator.Read more
1.80.0 ·Source§

implFromIterator<String> forBox<str>

Source§

fnfrom_iter<T>(iter: T) ->Box<str>
where T:IntoIterator<Item =String>,

Creates a value from an iterator.Read more
1.80.0 ·Source§

implFromIterator<char> forBox<str>

Source§

fnfrom_iter<T>(iter: T) ->Box<str>
where T:IntoIterator<Item =char>,

Creates a value from an iterator.Read more
1.0.0 ·Source§

implHash forstr

Source§

fnhash<H>(&self, state:&mut H)
where H:Hasher,

Feeds this value into the givenHasher.Read more
1.0.0 (const:unstable) ·Source§

impl<I>Index<I> forstr
where I:SliceIndex<str>,

Source§

typeOutput = <I asSliceIndex<str>>::Output

The returned type after indexing.
Source§

fnindex(&self, index: I) -> &<I asSliceIndex<str>>::Output

Performs the indexing (container[index]) operation.Read more
1.0.0 (const:unstable) ·Source§

impl<I>IndexMut<I> forstr
where I:SliceIndex<str>,

Source§

fnindex_mut(&mut self, index: I) -> &mut <I asSliceIndex<str>>::Output

Performs the mutable indexing (container[index]) operation.Read more
Source§

impl<S>Join<&str> for[S]
where S:Borrow<str>,

Source§

typeOutput =String

🔬This is a nightly-only experimental API. (slice_concat_trait #27747)
The resulting type after concatenation
Source§

fnjoin(slice: &[S], sep: &str) ->String

🔬This is a nightly-only experimental API. (slice_concat_trait #27747)
Implementation of[T]::join
1.0.0 ·Source§

implOrd forstr

Implements ordering of strings.

Strings are orderedlexicographically by their byte values. This orders Unicode codepoints based on their positions in the code charts. This is not necessarily the same as“alphabetical” order, which varies by language and locale. Sorting strings according toculturally-accepted standards requires locale-specific data that is outside the scope ofthestr type.

Source§

fncmp(&self, other: &str) ->Ordering

This method returns anOrdering betweenself andother.Read more
Source§

impl<'a>PartialEq<&str> forByteStr

Source§

fneq(&self, other: &&str) ->bool

Tests forself andother values to be equal, and is used by==.
1.0.0 ·Source§

fnne(&self, other:&Rhs) ->bool

Tests for!=. The default implementation is almost always sufficient,and should not be overridden without very good reason.
Source§

impl<'a>PartialEq<&str> forByteString

Source§

fneq(&self, other: &&str) ->bool

Tests forself andother values to be equal, and is used by==.
1.0.0 ·Source§

fnne(&self, other:&Rhs) ->bool

Tests for!=. The default implementation is almost always sufficient,and should not be overridden without very good reason.
1.0.0 ·Source§

impl<'a, 'b>PartialEq<&'bstr> forCow<'a,str>

Source§

fneq(&self, other: &&'bstr) ->bool

Tests forself andother values to be equal, and is used by==.
Source§

fnne(&self, other: &&'bstr) ->bool

Tests for!=. The default implementation is almost always sufficient,and should not be overridden without very good reason.
1.29.0 ·Source§

implPartialEq<&str> forOsString

Source§

fneq(&self, other: &&str) ->bool

Tests forself andother values to be equal, and is used by==.
1.0.0 ·Source§

fnne(&self, other:&Rhs) ->bool

Tests for!=. The default implementation is almost always sufficient,and should not be overridden without very good reason.
1.0.0 ·Source§

impl<'a, 'b>PartialEq<&'astr> forString

Source§

fneq(&self, other: &&'astr) ->bool

Tests forself andother values to be equal, and is used by==.
Source§

fnne(&self, other: &&'astr) ->bool

Tests for!=. The default implementation is almost always sufficient,and should not be overridden without very good reason.
Source§

impl<'a>PartialEq<ByteStr> for &str

Source§

fneq(&self, other: &ByteStr) ->bool

Tests forself andother values to be equal, and is used by==.
1.0.0 ·Source§

fnne(&self, other:&Rhs) ->bool

Tests for!=. The default implementation is almost always sufficient,and should not be overridden without very good reason.
Source§

impl<'a>PartialEq<ByteStr> forstr

Source§

fneq(&self, other: &ByteStr) ->bool

Tests forself andother values to be equal, and is used by==.
1.0.0 ·Source§

fnne(&self, other:&Rhs) ->bool

Tests for!=. The default implementation is almost always sufficient,and should not be overridden without very good reason.
Source§

impl<'a>PartialEq<ByteString> for &str

Source§

fneq(&self, other: &ByteString) ->bool

Tests forself andother values to be equal, and is used by==.
1.0.0 ·Source§

fnne(&self, other:&Rhs) ->bool

Tests for!=. The default implementation is almost always sufficient,and should not be overridden without very good reason.
Source§

impl<'a>PartialEq<ByteString> forstr

Source§

fneq(&self, other: &ByteString) ->bool

Tests forself andother values to be equal, and is used by==.
1.0.0 ·Source§

fnne(&self, other:&Rhs) ->bool

Tests for!=. The default implementation is almost always sufficient,and should not be overridden without very good reason.
1.0.0 ·Source§

impl<'a, 'b>PartialEq<Cow<'a,str>> for &'bstr

Source§

fneq(&self, other: &Cow<'a,str>) ->bool

Tests forself andother values to be equal, and is used by==.
Source§

fnne(&self, other: &Cow<'a,str>) ->bool

Tests for!=. The default implementation is almost always sufficient,and should not be overridden without very good reason.
1.0.0 ·Source§

impl<'a, 'b>PartialEq<Cow<'a,str>> forstr

Source§

fneq(&self, other: &Cow<'a,str>) ->bool

Tests forself andother values to be equal, and is used by==.
Source§

fnne(&self, other: &Cow<'a,str>) ->bool

Tests for!=. The default implementation is almost always sufficient,and should not be overridden without very good reason.
1.0.0 ·Source§

implPartialEq<OsStr> forstr

Source§

fneq(&self, other: &OsStr) ->bool

Tests forself andother values to be equal, and is used by==.
1.0.0 ·Source§

fnne(&self, other:&Rhs) ->bool

Tests for!=. The default implementation is almost always sufficient,and should not be overridden without very good reason.
1.29.0 ·Source§

impl<'a>PartialEq<OsString> for &'astr

Source§

fneq(&self, other: &OsString) ->bool

Tests forself andother values to be equal, and is used by==.
1.0.0 ·Source§

fnne(&self, other:&Rhs) ->bool

Tests for!=. The default implementation is almost always sufficient,and should not be overridden without very good reason.
1.0.0 ·Source§

implPartialEq<OsString> forstr

Source§

fneq(&self, other: &OsString) ->bool

Tests forself andother values to be equal, and is used by==.
1.0.0 ·Source§

fnne(&self, other:&Rhs) ->bool

Tests for!=. The default implementation is almost always sufficient,and should not be overridden without very good reason.
1.91.0 ·Source§

implPartialEq<Path> forstr

Source§

fneq(&self, other: &Path) ->bool

Tests forself andother values to be equal, and is used by==.
1.0.0 ·Source§

fnne(&self, other:&Rhs) ->bool

Tests for!=. The default implementation is almost always sufficient,and should not be overridden without very good reason.
1.91.0 ·Source§

implPartialEq<PathBuf> forstr

Source§

fneq(&self, other: &PathBuf) ->bool

Tests forself andother values to be equal, and is used by==.
1.0.0 ·Source§

fnne(&self, other:&Rhs) ->bool

Tests for!=. The default implementation is almost always sufficient,and should not be overridden without very good reason.
1.0.0 ·Source§

impl<'a, 'b>PartialEq<String> for &'astr

Source§

fneq(&self, other: &String) ->bool

Tests forself andother values to be equal, and is used by==.
Source§

fnne(&self, other: &String) ->bool

Tests for!=. The default implementation is almost always sufficient,and should not be overridden without very good reason.
1.0.0 ·Source§

impl<'a, 'b>PartialEq<String> forstr

Source§

fneq(&self, other: &String) ->bool

Tests forself andother values to be equal, and is used by==.
Source§

fnne(&self, other: &String) ->bool

Tests for!=. The default implementation is almost always sufficient,and should not be overridden without very good reason.
Source§

impl<'a>PartialEq<str> forByteStr

Source§

fneq(&self, other: &str) ->bool

Tests forself andother values to be equal, and is used by==.
1.0.0 ·Source§

fnne(&self, other:&Rhs) ->bool

Tests for!=. The default implementation is almost always sufficient,and should not be overridden without very good reason.
Source§

impl<'a>PartialEq<str> forByteString

Source§

fneq(&self, other: &str) ->bool

Tests forself andother values to be equal, and is used by==.
1.0.0 ·Source§

fnne(&self, other:&Rhs) ->bool

Tests for!=. The default implementation is almost always sufficient,and should not be overridden without very good reason.
1.0.0 ·Source§

impl<'a, 'b>PartialEq<str> forCow<'a,str>

Source§

fneq(&self, other: &str) ->bool

Tests forself andother values to be equal, and is used by==.
Source§

fnne(&self, other: &str) ->bool

Tests for!=. The default implementation is almost always sufficient,and should not be overridden without very good reason.
1.0.0 ·Source§

implPartialEq<str> forOsStr

Source§

fneq(&self, other: &str) ->bool

Tests forself andother values to be equal, and is used by==.
1.0.0 ·Source§

fnne(&self, other:&Rhs) ->bool

Tests for!=. The default implementation is almost always sufficient,and should not be overridden without very good reason.
1.0.0 ·Source§

implPartialEq<str> forOsString

Source§

fneq(&self, other: &str) ->bool

Tests forself andother values to be equal, and is used by==.
1.0.0 ·Source§

fnne(&self, other:&Rhs) ->bool

Tests for!=. The default implementation is almost always sufficient,and should not be overridden without very good reason.
1.91.0 ·Source§

implPartialEq<str> forPath

Source§

fneq(&self, other: &str) ->bool

Tests forself andother values to be equal, and is used by==.
1.0.0 ·Source§

fnne(&self, other:&Rhs) ->bool

Tests for!=. The default implementation is almost always sufficient,and should not be overridden without very good reason.
1.91.0 ·Source§

implPartialEq<str> forPathBuf

Source§

fneq(&self, other: &str) ->bool

Tests forself andother values to be equal, and is used by==.
1.0.0 ·Source§

fnne(&self, other:&Rhs) ->bool

Tests for!=. The default implementation is almost always sufficient,and should not be overridden without very good reason.
1.0.0 ·Source§

impl<'a, 'b>PartialEq<str> forString

Source§

fneq(&self, other: &str) ->bool

Tests forself andother values to be equal, and is used by==.
Source§

fnne(&self, other: &str) ->bool

Tests for!=. The default implementation is almost always sufficient,and should not be overridden without very good reason.
1.0.0 (const:unstable) ·Source§

implPartialEq forstr

Source§

fneq(&self, other: &str) ->bool

Tests forself andother values to be equal, and is used by==.
1.0.0 ·Source§

fnne(&self, other:&Rhs) ->bool

Tests for!=. The default implementation is almost always sufficient,and should not be overridden without very good reason.
1.0.0 ·Source§

implPartialOrd<str> forOsStr

Source§

fnpartial_cmp(&self, other: &str) ->Option<Ordering>

This method returns an ordering betweenself andother values if one exists.Read more
1.0.0 ·Source§

fnlt(&self, other:&Rhs) ->bool

Tests less than (forself andother) and is used by the< operator.Read more
1.0.0 ·Source§

fnle(&self, other:&Rhs) ->bool

Tests less than or equal to (forself andother) and is used by the<= operator.Read more
1.0.0 ·Source§

fngt(&self, other:&Rhs) ->bool

Tests greater than (forself andother) and is used by the>operator.Read more
1.0.0 ·Source§

fnge(&self, other:&Rhs) ->bool

Tests greater than or equal to (forself andother) and is used bythe>= operator.Read more
1.0.0 ·Source§

implPartialOrd<str> forOsString

Source§

fnpartial_cmp(&self, other: &str) ->Option<Ordering>

This method returns an ordering betweenself andother values if one exists.Read more
1.0.0 ·Source§

fnlt(&self, other:&Rhs) ->bool

Tests less than (forself andother) and is used by the< operator.Read more
1.0.0 ·Source§

fnle(&self, other:&Rhs) ->bool

Tests less than or equal to (forself andother) and is used by the<= operator.Read more
1.0.0 ·Source§

fngt(&self, other:&Rhs) ->bool

Tests greater than (forself andother) and is used by the>operator.Read more
1.0.0 ·Source§

fnge(&self, other:&Rhs) ->bool

Tests greater than or equal to (forself andother) and is used bythe>= operator.Read more
1.0.0 ·Source§

implPartialOrd forstr

Implements comparison operations on strings.

Strings are comparedlexicographically by their byte values. This compares Unicode codepoints based on their positions in the code charts. This is not necessarily the same as“alphabetical” order, which varies by language and locale. Comparing strings according toculturally-accepted standards requires locale-specific data that is outside the scope ofthestr type.

Source§

fnpartial_cmp(&self, other: &str) ->Option<Ordering>

This method returns an ordering betweenself andother values if one exists.Read more
1.0.0 ·Source§

fnlt(&self, other:&Rhs) ->bool

Tests less than (forself andother) and is used by the< operator.Read more
1.0.0 ·Source§

fnle(&self, other:&Rhs) ->bool

Tests less than or equal to (forself andother) and is used by the<= operator.Read more
1.0.0 ·Source§

fngt(&self, other:&Rhs) ->bool

Tests greater than (forself andother) and is used by the>operator.Read more
1.0.0 ·Source§

fnge(&self, other:&Rhs) ->bool

Tests greater than or equal to (forself andother) and is used bythe>= operator.Read more
Source§

impl<'b>Pattern for &'bstr

Non-allocating substring search.

Will handle the pattern"" as returning empty matches at each characterboundary.

§Examples

assert_eq!("Hello world".find("world"),Some(6));
Source§

fnis_prefix_of(self, haystack: &str) ->bool

🔬This is a nightly-only experimental API. (pattern #27721)

Checks whether the pattern matches at the front of the haystack.

Source§

fnis_contained_in(self, haystack: &str) ->bool

🔬This is a nightly-only experimental API. (pattern #27721)

Checks whether the pattern matches anywhere in the haystack

Source§

fnstrip_prefix_of(self, haystack: &str) ->Option<&str>

🔬This is a nightly-only experimental API. (pattern #27721)

Removes the pattern from the front of haystack, if it matches.

Source§

fnis_suffix_of<'a>(self, haystack: &'astr) ->bool
where <&'bstr asPattern>::Searcher<'a>:ReverseSearcher<'a>,

🔬This is a nightly-only experimental API. (pattern #27721)

Checks whether the pattern matches at the back of the haystack.

Source§

fnstrip_suffix_of<'a>(self, haystack: &'astr) ->Option<&'astr>
where <&'bstr asPattern>::Searcher<'a>:ReverseSearcher<'a>,

🔬This is a nightly-only experimental API. (pattern #27721)

Removes the pattern from the back of haystack, if it matches.

Source§

typeSearcher<'a> =StrSearcher<'a, 'b>

🔬This is a nightly-only experimental API. (pattern #27721)
Associated searcher for this pattern
Source§

fninto_searcher(self, haystack: &str) ->StrSearcher<'_, 'b>

🔬This is a nightly-only experimental API. (pattern #27721)
Constructs the associated searcher fromself and thehaystack to search in.
Source§

fnas_utf8_pattern(&self) ->Option<Utf8Pattern<'_>>

🔬This is a nightly-only experimental API. (pattern #27721)
Returns the pattern as utf-8 bytes if possible.
1.73.0 ·Source§

implSliceIndex<str> for (Bound<usize>,Bound<usize>)

Implements substring slicing for arbitrary bounds.

Returns a slice of the given string bounded by the byte indicesprovided by each bound.

This operation isO(1).

§Panics

Panics ifbegin orend (if it exists and once adjusted forinclusion/exclusion) does not point to the starting byte offset ofa character (as defined byis_char_boundary), ifbegin > end, or ifend > len.

Source§

typeOutput =str

The output type returned by methods.
Source§

fnget(self, slice: &str) ->Option<&str>

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a shared reference to the output at this location, if inbounds.
Source§

fnget_mut(self, slice: &mutstr) ->Option<&mutstr>

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a mutable reference to the output at this location, if inbounds.
Source§

unsafe fnget_unchecked(self, slice:*conststr) ->*conststr

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a pointer to the output at this location, withoutperforming any bounds checking.Read more
Source§

unsafe fnget_unchecked_mut(self, slice:*mutstr) ->*mutstr

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a mutable pointer to the output at this location, withoutperforming any bounds checking.Read more
Source§

fnindex(self, slice: &str) -> &str

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a shared reference to the output at this location, panickingif out of bounds.
Source§

fnindex_mut(self, slice: &mutstr) -> &mutstr

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a mutable reference to the output at this location, panickingif out of bounds.
1.20.0 (const:unstable) ·Source§

implSliceIndex<str> forRange<usize>

Implements substring slicing with syntax&self[begin .. end] or&mut self[begin .. end].

Returns a slice of the given string from the byte range[begin,end).

This operation isO(1).

Prior to 1.20.0, these indexing operations were still supported bydirect implementation ofIndex andIndexMut.

§Panics

Panics ifbegin orend does not point to the starting byte offset ofa character (as defined byis_char_boundary), ifbegin > end, or ifend > len.

§Examples

lets ="Löwe 老虎 Léopard";assert_eq!(&s[0..1],"L");assert_eq!(&s[1..9],"öwe 老");// these will panic:// byte 2 lies within `ö`:// &s[2 ..3];// byte 8 lies within `老`// &s[1 .. 8];// byte 100 is outside the string// &s[3 .. 100];
Source§

typeOutput =str

The output type returned by methods.
Source§

fnget(self, slice: &str) ->Option<&<Range<usize> asSliceIndex<str>>::Output>

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a shared reference to the output at this location, if inbounds.
Source§

fnget_mut( self, slice: &mutstr,) ->Option<&mut <Range<usize> asSliceIndex<str>>::Output>

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a mutable reference to the output at this location, if inbounds.
Source§

unsafe fnget_unchecked( self, slice:*conststr,) ->*const<Range<usize> asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a pointer to the output at this location, withoutperforming any bounds checking.Read more
Source§

unsafe fnget_unchecked_mut( self, slice:*mutstr,) ->*mut<Range<usize> asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a mutable pointer to the output at this location, withoutperforming any bounds checking.Read more
Source§

fnindex(self, slice: &str) -> &<Range<usize> asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a shared reference to the output at this location, panickingif out of bounds.
Source§

fnindex_mut( self, slice: &mutstr,) -> &mut <Range<usize> asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a mutable reference to the output at this location, panickingif out of bounds.
Source§

implSliceIndex<str> forRange<usize>

Source§

typeOutput =str

The output type returned by methods.
Source§

fnget(self, slice: &str) ->Option<&<Range<usize> asSliceIndex<str>>::Output>

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a shared reference to the output at this location, if inbounds.
Source§

fnget_mut( self, slice: &mutstr,) ->Option<&mut <Range<usize> asSliceIndex<str>>::Output>

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a mutable reference to the output at this location, if inbounds.
Source§

unsafe fnget_unchecked( self, slice:*conststr,) ->*const<Range<usize> asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a pointer to the output at this location, withoutperforming any bounds checking.Read more
Source§

unsafe fnget_unchecked_mut( self, slice:*mutstr,) ->*mut<Range<usize> asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a mutable pointer to the output at this location, withoutperforming any bounds checking.Read more
Source§

fnindex(self, slice: &str) -> &<Range<usize> asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a shared reference to the output at this location, panickingif out of bounds.
Source§

fnindex_mut( self, slice: &mutstr,) -> &mut <Range<usize> asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a mutable reference to the output at this location, panickingif out of bounds.
1.20.0 (const:unstable) ·Source§

implSliceIndex<str> forRangeFrom<usize>

Implements substring slicing with syntax&self[begin ..] or&mut self[begin ..].

Returns a slice of the given string from the byte range [begin,len).Equivalent to&self[begin .. len] or&mut self[begin .. len].

This operation isO(1).

Prior to 1.20.0, these indexing operations were still supported bydirect implementation ofIndex andIndexMut.

§Panics

Panics ifbegin does not point to the starting byte offset ofa character (as defined byis_char_boundary), or ifbegin > len.

Source§

typeOutput =str

The output type returned by methods.
Source§

fnget( self, slice: &str,) ->Option<&<RangeFrom<usize> asSliceIndex<str>>::Output>

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a shared reference to the output at this location, if inbounds.
Source§

fnget_mut( self, slice: &mutstr,) ->Option<&mut <RangeFrom<usize> asSliceIndex<str>>::Output>

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a mutable reference to the output at this location, if inbounds.
Source§

unsafe fnget_unchecked( self, slice:*conststr,) ->*const<RangeFrom<usize> asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a pointer to the output at this location, withoutperforming any bounds checking.Read more
Source§

unsafe fnget_unchecked_mut( self, slice:*mutstr,) ->*mut<RangeFrom<usize> asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a mutable pointer to the output at this location, withoutperforming any bounds checking.Read more
Source§

fnindex(self, slice: &str) -> &<RangeFrom<usize> asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a shared reference to the output at this location, panickingif out of bounds.
Source§

fnindex_mut( self, slice: &mutstr,) -> &mut <RangeFrom<usize> asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a mutable reference to the output at this location, panickingif out of bounds.
Source§

implSliceIndex<str> forRangeFrom<usize>

Source§

typeOutput =str

The output type returned by methods.
Source§

fnget( self, slice: &str,) ->Option<&<RangeFrom<usize> asSliceIndex<str>>::Output>

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a shared reference to the output at this location, if inbounds.
Source§

fnget_mut( self, slice: &mutstr,) ->Option<&mut <RangeFrom<usize> asSliceIndex<str>>::Output>

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a mutable reference to the output at this location, if inbounds.
Source§

unsafe fnget_unchecked( self, slice:*conststr,) ->*const<RangeFrom<usize> asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a pointer to the output at this location, withoutperforming any bounds checking.Read more
Source§

unsafe fnget_unchecked_mut( self, slice:*mutstr,) ->*mut<RangeFrom<usize> asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a mutable pointer to the output at this location, withoutperforming any bounds checking.Read more
Source§

fnindex(self, slice: &str) -> &<RangeFrom<usize> asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a shared reference to the output at this location, panickingif out of bounds.
Source§

fnindex_mut( self, slice: &mutstr,) -> &mut <RangeFrom<usize> asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a mutable reference to the output at this location, panickingif out of bounds.
1.20.0 (const:unstable) ·Source§

implSliceIndex<str> forRangeFull

Implements substring slicing with syntax&self[..] or&mut self[..].

Returns a slice of the whole string, i.e., returns&self or&mut self. Equivalent to&self[0 .. len] or&mut self[0 .. len]. Unlikeother indexing operations, this can never panic.

This operation isO(1).

Prior to 1.20.0, these indexing operations were still supported bydirect implementation ofIndex andIndexMut.

Equivalent to&self[0 .. len] or&mut self[0 .. len].

Source§

typeOutput =str

The output type returned by methods.
Source§

fnget(self, slice: &str) ->Option<&<RangeFull asSliceIndex<str>>::Output>

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a shared reference to the output at this location, if inbounds.
Source§

fnget_mut( self, slice: &mutstr,) ->Option<&mut <RangeFull asSliceIndex<str>>::Output>

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a mutable reference to the output at this location, if inbounds.
Source§

unsafe fnget_unchecked( self, slice:*conststr,) ->*const<RangeFull asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a pointer to the output at this location, withoutperforming any bounds checking.Read more
Source§

unsafe fnget_unchecked_mut( self, slice:*mutstr,) ->*mut<RangeFull asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a mutable pointer to the output at this location, withoutperforming any bounds checking.Read more
Source§

fnindex(self, slice: &str) -> &<RangeFull asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a shared reference to the output at this location, panickingif out of bounds.
Source§

fnindex_mut( self, slice: &mutstr,) -> &mut <RangeFull asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a mutable reference to the output at this location, panickingif out of bounds.
1.26.0 (const:unstable) ·Source§

implSliceIndex<str> forRangeInclusive<usize>

Implements substring slicing with syntax&self[begin ..= end] or&mut self[begin ..= end].

Returns a slice of the given string from the byte range[begin,end]. Equivalent to&self [begin .. end + 1] or&mut self[begin .. end + 1], except ifend has the maximum value forusize.

This operation isO(1).

§Panics

Panics ifbegin does not point to the starting byte offset ofa character (as defined byis_char_boundary), ifend does not pointto the ending byte offset of a character (end + 1 is either a startingbyte offset or equal tolen), ifbegin > end, or ifend >= len.

Source§

typeOutput =str

The output type returned by methods.
Source§

fnget( self, slice: &str,) ->Option<&<RangeInclusive<usize> asSliceIndex<str>>::Output>

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a shared reference to the output at this location, if inbounds.
Source§

fnget_mut( self, slice: &mutstr,) ->Option<&mut <RangeInclusive<usize> asSliceIndex<str>>::Output>

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a mutable reference to the output at this location, if inbounds.
Source§

unsafe fnget_unchecked( self, slice:*conststr,) ->*const<RangeInclusive<usize> asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a pointer to the output at this location, withoutperforming any bounds checking.Read more
Source§

unsafe fnget_unchecked_mut( self, slice:*mutstr,) ->*mut<RangeInclusive<usize> asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a mutable pointer to the output at this location, withoutperforming any bounds checking.Read more
Source§

fnindex( self, slice: &str,) -> &<RangeInclusive<usize> asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a shared reference to the output at this location, panickingif out of bounds.
Source§

fnindex_mut( self, slice: &mutstr,) -> &mut <RangeInclusive<usize> asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a mutable reference to the output at this location, panickingif out of bounds.
Source§

implSliceIndex<str> forRangeInclusive<usize>

Source§

typeOutput =str

The output type returned by methods.
Source§

fnget( self, slice: &str,) ->Option<&<RangeInclusive<usize> asSliceIndex<str>>::Output>

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a shared reference to the output at this location, if inbounds.
Source§

fnget_mut( self, slice: &mutstr,) ->Option<&mut <RangeInclusive<usize> asSliceIndex<str>>::Output>

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a mutable reference to the output at this location, if inbounds.
Source§

unsafe fnget_unchecked( self, slice:*conststr,) ->*const<RangeInclusive<usize> asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a pointer to the output at this location, withoutperforming any bounds checking.Read more
Source§

unsafe fnget_unchecked_mut( self, slice:*mutstr,) ->*mut<RangeInclusive<usize> asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a mutable pointer to the output at this location, withoutperforming any bounds checking.Read more
Source§

fnindex( self, slice: &str,) -> &<RangeInclusive<usize> asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a shared reference to the output at this location, panickingif out of bounds.
Source§

fnindex_mut( self, slice: &mutstr,) -> &mut <RangeInclusive<usize> asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a mutable reference to the output at this location, panickingif out of bounds.
1.20.0 (const:unstable) ·Source§

implSliceIndex<str> forRangeTo<usize>

Implements substring slicing with syntax&self[.. end] or&mut self[.. end].

Returns a slice of the given string from the byte range [0,end).Equivalent to&self[0 .. end] or&mut self[0 .. end].

This operation isO(1).

Prior to 1.20.0, these indexing operations were still supported bydirect implementation ofIndex andIndexMut.

§Panics

Panics ifend does not point to the starting byte offset of acharacter (as defined byis_char_boundary), or ifend > len.

Source§

typeOutput =str

The output type returned by methods.
Source§

fnget( self, slice: &str,) ->Option<&<RangeTo<usize> asSliceIndex<str>>::Output>

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a shared reference to the output at this location, if inbounds.
Source§

fnget_mut( self, slice: &mutstr,) ->Option<&mut <RangeTo<usize> asSliceIndex<str>>::Output>

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a mutable reference to the output at this location, if inbounds.
Source§

unsafe fnget_unchecked( self, slice:*conststr,) ->*const<RangeTo<usize> asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a pointer to the output at this location, withoutperforming any bounds checking.Read more
Source§

unsafe fnget_unchecked_mut( self, slice:*mutstr,) ->*mut<RangeTo<usize> asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a mutable pointer to the output at this location, withoutperforming any bounds checking.Read more
Source§

fnindex(self, slice: &str) -> &<RangeTo<usize> asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a shared reference to the output at this location, panickingif out of bounds.
Source§

fnindex_mut( self, slice: &mutstr,) -> &mut <RangeTo<usize> asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a mutable reference to the output at this location, panickingif out of bounds.
1.26.0 (const:unstable) ·Source§

implSliceIndex<str> forRangeToInclusive<usize>

Implements substring slicing with syntax&self[..= end] or&mut self[..= end].

Returns a slice of the given string from the byte range [0,end].Equivalent to&self [0 .. end + 1], except ifend has the maximumvalue forusize.

This operation isO(1).

§Panics

Panics ifend does not point to the ending byte offset of a character(end + 1 is either a starting byte offset as defined byis_char_boundary, or equal tolen), or ifend >= len.

Source§

typeOutput =str

The output type returned by methods.
Source§

fnget( self, slice: &str,) ->Option<&<RangeToInclusive<usize> asSliceIndex<str>>::Output>

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a shared reference to the output at this location, if inbounds.
Source§

fnget_mut( self, slice: &mutstr,) ->Option<&mut <RangeToInclusive<usize> asSliceIndex<str>>::Output>

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a mutable reference to the output at this location, if inbounds.
Source§

unsafe fnget_unchecked( self, slice:*conststr,) ->*const<RangeToInclusive<usize> asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a pointer to the output at this location, withoutperforming any bounds checking.Read more
Source§

unsafe fnget_unchecked_mut( self, slice:*mutstr,) ->*mut<RangeToInclusive<usize> asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a mutable pointer to the output at this location, withoutperforming any bounds checking.Read more
Source§

fnindex( self, slice: &str,) -> &<RangeToInclusive<usize> asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a shared reference to the output at this location, panickingif out of bounds.
Source§

fnindex_mut( self, slice: &mutstr,) -> &mut <RangeToInclusive<usize> asSliceIndex<str>>::Output

🔬This is a nightly-only experimental API. (slice_index_methods)
Returns a mutable reference to the output at this location, panickingif out of bounds.
1.0.0 ·Source§

implToOwned forstr

Source§

typeOwned =String

The resulting type after obtaining ownership.
Source§

fnto_owned(&self) ->String

Creates owned data from borrowed data, usually by cloning.Read more
Source§

fnclone_into(&self, target: &mutString)

Uses borrowed data to replace owned data, usually by cloning.Read more
1.0.0 ·Source§

implToSocketAddrs forstr

Source§

typeIter =IntoIter<SocketAddr>

Returned iterator over socket addresses which this type may correspondto.
Source§

fnto_socket_addrs(&self) ->Result<IntoIter<SocketAddr>>

Converts this object to an iterator of resolvedSocketAddrs.Read more
Source§

impl<'a>TryFrom<&'aByteStr> for &'astr

Source§

typeError =Utf8Error

The type returned in the event of a conversion error.
Source§

fntry_from( s: &'aByteStr,) ->Result<&'astr, <&'astr asTryFrom<&'aByteStr>>::Error>

Performs the conversion.
Source§

impl<'a>TryFrom<&'aByteString> for &'astr

Source§

typeError =Utf8Error

The type returned in the event of a conversion error.
Source§

fntry_from( s: &'aByteString,) ->Result<&'astr, <&'astr asTryFrom<&'aByteString>>::Error>

Performs the conversion.
1.72.0 ·Source§

impl<'a>TryFrom<&'aOsStr> for &'astr

Source§

fntry_from(value: &'aOsStr) ->Result<Self, Self::Error>

Tries to convert an&OsStr to a&str.

usestd::ffi::OsStr;letos_str = OsStr::new("foo");letas_str = <&str>::try_from(os_str).unwrap();assert_eq!(as_str,"foo");
Source§

typeError =Utf8Error

The type returned in the event of a conversion error.
Source§

impl<'a>TryFrom<&'a mutByteStr> for &'a mutstr

Source§

typeError =Utf8Error

The type returned in the event of a conversion error.
Source§

fntry_from( s: &'a mutByteStr,) ->Result<&'a mutstr, <&'a mutstr asTryFrom<&'a mutByteStr>>::Error>

Performs the conversion.
Source§

implConstParamTy_ forstr

1.0.0 (const:unstable) ·Source§

implEq forstr

1.65.0 ·Source§

impl !Error for &str

Source§

implStructuralPartialEq forstr

Auto Trait Implementations§

§

implFreeze forstr

§

implRefUnwindSafe forstr

§

implSend forstr

§

impl !Sized forstr

§

implSync forstr

§

implUnpin forstr

§

implUnwindSafe forstr

Blanket Implementations§

Source§

impl<T>Any for T
where T: 'static + ?Sized,

Source§

fntype_id(&self) ->TypeId

Gets theTypeId ofself.Read more
Source§

impl<T>Borrow<T> for T
where T: ?Sized,

Source§

fnborrow(&self) ->&T

Immutably borrows from an owned value.Read more
Source§

impl<T>BorrowMut<T> for T
where T: ?Sized,

Source§

fnborrow_mut(&mut self) ->&mut T

Mutably borrows from an owned value.Read more
Source§

impl<T>ToString for T
where T:Display + ?Sized,

Source§

fnto_string(&self) ->String

Converts the given value to aString.Read more

[8]ページ先頭

©2009-2026 Movatter.jp