Struct FromUtf8Error
struct FromUtf8Error { ... }
A possible error value when converting a String from a UTF-8 byte vector.
This type is the error type for the from_utf8 method on String. It
is designed in such a way to carefully avoid reallocations: the
into_bytes method will give back the byte vector that was used in the
conversion attempt.
The Utf8Error type provided by std::str represents an error that may
occur when converting a slice of u8s to a &str. In this sense, it's
an analogue to FromUtf8Error, and you can get one from a FromUtf8Error
through the utf8_error method.
Examples
// some invalid bytes, in a vector
let bytes = vec!;
let value = Stringfrom_utf8;
assert!;
assert_eq!;
Implementations
impl FromUtf8Error
fn as_bytes(self: &Self) -> &[u8]Returns a slice of
u8s bytes that were attempted to convert to aString.Examples
// some invalid bytes, in a vector let bytes = vec!; let value = Stringfrom_utf8; assert_eq!;fn into_utf8_lossy(self: Self) -> StringConverts the bytes into a
Stringlossily, substituting invalid UTF-8 sequences with replacement characters.See
String::from_utf8_lossyfor more details on replacement of invalid sequences, andString::from_utf8_lossy_ownedfor theStringfunction which corresponds to this function.Examples
// some invalid bytes let input: = b"Hello \xF0\x90\x80World".into; let output = Stringfrom_utf8.unwrap_or_else; assert_eq!;fn into_bytes(self: Self) -> Vec<u8>Returns the bytes that were attempted to convert to a
String.This method is carefully constructed to avoid allocation. It will consume the error, moving out the bytes, so that a copy of the bytes does not need to be made.
Examples
// some invalid bytes, in a vector let bytes = vec!; let value = Stringfrom_utf8; assert_eq!;fn utf8_error(self: &Self) -> Utf8ErrorFetch a
Utf8Errorto get more details about the conversion failure.The
Utf8Errortype provided bystd::strrepresents an error that may occur when converting a slice ofu8s to a&str. In this sense, it's an analogue toFromUtf8Error. See its documentation for more details on using it.Examples
// some invalid bytes, in a vector let bytes = vec!; let error = Stringfrom_utf8.unwrap_err.utf8_error; // the first byte is invalid here assert_eq!;
impl Clone for FromUtf8Error
fn clone(self: &Self) -> FromUtf8Error
impl Debug for FromUtf8Error
fn fmt(self: &Self, f: &mut $crate::fmt::Formatter<'_>) -> $crate::fmt::Result
impl Display for FromUtf8Error
fn fmt(self: &Self, f: &mut fmt::Formatter<'_>) -> fmt::Result
impl Eq for FromUtf8Error
impl Error for FromUtf8Error
impl Freeze for FromUtf8Error
impl PartialEq for FromUtf8Error
fn eq(self: &Self, other: &FromUtf8Error) -> bool
impl RefUnwindSafe for FromUtf8Error
impl Send for FromUtf8Error
impl StructuralPartialEq for FromUtf8Error
impl Sync for FromUtf8Error
impl Unpin for FromUtf8Error
impl UnwindSafe for FromUtf8Error
impl<T> Any for FromUtf8Error
fn type_id(self: &Self) -> TypeId
impl<T> Borrow for FromUtf8Error
fn borrow(self: &Self) -> &T
impl<T> BorrowMut for FromUtf8Error
fn borrow_mut(self: &mut Self) -> &mut T
impl<T> CloneToUninit for FromUtf8Error
unsafe fn clone_to_uninit(self: &Self, dest: *mut u8)
impl<T> From for FromUtf8Error
fn from(t: T) -> TReturns the argument unchanged.
impl<T> ToOwned for FromUtf8Error
fn to_owned(self: &Self) -> Tfn clone_into(self: &Self, target: &mut T)
impl<T> ToString for FromUtf8Error
fn to_string(self: &Self) -> String
impl<T, U> Into for FromUtf8Error
fn into(self: Self) -> UCalls
U::from(self).That is, this conversion is whatever the implementation of
[From]<T> for Uchooses to do.
impl<T, U> TryFrom for FromUtf8Error
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
impl<T, U> TryInto for FromUtf8Error
fn try_into(self: Self) -> Result<U, <U as TryFrom<T>>::Error>