ReadOnlySpan<T> Структура
Определение
Важно!
Некоторые сведения относятся к предварительной версии продукта, в которую до выпуска могут быть внесены существенные изменения. Майкрософт не предоставляет никаких гарантий, явных или подразумеваемых, относительно приведенных здесь сведений.
Предоставляет типобезопасное и безопасное для чтения представление непрерывной области произвольной памяти.
generic <typename T>
public value class ReadOnlySpan
public readonly ref struct ReadOnlySpan<T>
[System.Runtime.InteropServices.Marshalling.NativeMarshalling(typeof(System.Runtime.InteropServices.Marshalling.ReadOnlySpanMarshaller<,>))]
public readonly ref struct ReadOnlySpan<T>
type ReadOnlySpan<'T> = struct
[<System.Runtime.InteropServices.Marshalling.NativeMarshalling(typeof(System.Runtime.InteropServices.Marshalling.ReadOnlySpanMarshaller<,>))>]
type ReadOnlySpan<'T> = struct
Public Structure ReadOnlySpan(Of T)
Параметры типа
- T
Тип элементов в ReadOnlySpan<T>.
- Наследование
- Атрибуты
Комментарии
ReadOnlySpan<T>
— это структуру ссылок, выделенную на стеке, и никогда не может бежать в управляемую кучу. Типы структур ссылок имеют ряд ограничений, чтобы гарантировать, что они не могут быть повышены до управляемой кучи, в том числе, что они не могут быть записаны в лямбда-выражениях, назначенных переменным типа Object, назначенным переменным dynamic
, и они не могут реализовать какой-либо тип интерфейса.
Экземпляр ReadOnlySpan<T>
часто используется для ссылки на элементы массива или части массива. В отличие от массива, однако экземпляр ReadOnlySpan<T>
может указывать на управляемую память, собственную память или память, управляемую в стеке.
Конструкторы
ReadOnlySpan<T>(T) |
Создает новую ReadOnlySpan<T> длины 1 вокруг указанной ссылки. |
ReadOnlySpan<T>(T[]) |
Создает новый ReadOnlySpan<T> по всей совокупности указанного массива. |
ReadOnlySpan<T>(T[], Int32, Int32) |
Создает новый ReadOnlySpan<T>, содержащий указанное число элементов массива, начиная с указанного индекса. |
ReadOnlySpan<T>(Void*, Int32) |
Создает новый ReadOnlySpan<T> из указанного числа элементов |
Свойства
Empty |
Возвращает пустую ReadOnlySpan<T>. |
IsEmpty |
Возвращает значение, указывающее, что текущий диапазон только для чтения пуст. |
Item[Int32] |
Возвращает элемент из диапазона только для чтения по указанному отсчитываемого от нуля индексу. |
Length |
Количество элементов в диапазоне только для чтения. |
Методы
CastUp<TDerived>(ReadOnlySpan<TDerived>) |
Приводит диапазон |
CopyTo(Span<T>) |
Копирует содержимое этого ReadOnlySpan<T> в целевой Span<T>. |
Equals(Object) |
Устаревшие..
Устаревшие..
Не поддерживается. Создает NotSupportedException. |
GetEnumerator() |
Возвращает перечислитель для этого ReadOnlySpan<T>. |
GetHashCode() |
Устаревшие..
Не поддерживается. Создает NotSupportedException. |
GetPinnableReference() |
Возвращает ссылку только для чтения на объект типа T, который можно использовать для закрепления. Этот метод предназначен для поддержки компиляторов .NET и не предназначен для вызова пользовательским кодом. |
Slice(Int32) |
Формирует срез из текущего диапазона только для чтения, который начинается с указанного индекса. |
Slice(Int32, Int32) |
Формирует срез из текущего диапазона только для чтения, начиная с указанного индекса для указанной длины. |
ToArray() |
Копирует содержимое этого диапазона только для чтения в новый массив. |
ToString() |
Возвращает строковое представление этого ReadOnlySpan<T>. |
TryCopyTo(Span<T>) |
Пытается скопировать содержимое этого ReadOnlySpan<T> в Span<T> и возвращает значение, указывающее, выполнена ли операция успешно. |
Операторы
Equality(ReadOnlySpan<T>, ReadOnlySpan<T>) |
Возвращает значение, указывающее, равны ли два экземпляра ReadOnlySpan<T>. |
Implicit(ArraySegment<T> to ReadOnlySpan<T>) |
Определяет неявное преобразование ArraySegment<T> в ReadOnlySpan<T>. |
Implicit(T[] to ReadOnlySpan<T>) |
Определяет неявное преобразование массива в ReadOnlySpan<T>. |
Inequality(ReadOnlySpan<T>, ReadOnlySpan<T>) |
Возвращает значение, указывающее, равны ли два экземпляра ReadOnlySpan<T>. |
Методы расширения
ToImmutableArray<T>(ReadOnlySpan<T>) |
Создайте неизменяемый массив содержимого из указанных элементов. |
BinarySearch<T>(ReadOnlySpan<T>, IComparable<T>) |
Выполняет поиск всего отсортированного ReadOnlySpan<T> значения с помощью указанного IComparable<T> универсального интерфейса. |
BinarySearch<T,TComparer>(ReadOnlySpan<T>, T, TComparer) |
Выполняет поиск всего отсортированного ReadOnlySpan<T> для указанного значения с помощью указанного |
BinarySearch<T,TComparable>(ReadOnlySpan<T>, TComparable) |
Выполняет поиск всего отсортированного ReadOnlySpan<T> значения с помощью указанного |
CommonPrefixLength<T>(ReadOnlySpan<T>, ReadOnlySpan<T>) |
Находит длину общего префикса между |
CommonPrefixLength<T>(ReadOnlySpan<T>, ReadOnlySpan<T>, IEqualityComparer<T>) |
Определяет длину общего префикса между |
Contains<T>(ReadOnlySpan<T>, T) |
Указывает, найдено ли указанное значение в диапазоне только для чтения. Значения сравниваются с помощью IEquatable{T}. Equals(T). |
ContainsAny<T>(ReadOnlySpan<T>, T, T) |
Выполняет поиск экземпляра |
ContainsAny<T>(ReadOnlySpan<T>, T, T, T) |
Выполняет поиск экземпляра |
ContainsAny<T>(ReadOnlySpan<T>, SearchValues<T>) |
Выполняет поиск любого из указанных |
ContainsAny<T>(ReadOnlySpan<T>, ReadOnlySpan<T>) |
Выполняет поиск любого из указанных |
ContainsAnyExcept<T>(ReadOnlySpan<T>, T) |
Выполняет поиск любого значения, отличного от указанного |
ContainsAnyExcept<T>(ReadOnlySpan<T>, T, T) |
Выполняет поиск любого значения, отличного от |
ContainsAnyExcept<T>(ReadOnlySpan<T>, T, T, T) |
Выполняет поиск любого значения, отличного от |
ContainsAnyExcept<T>(ReadOnlySpan<T>, SearchValues<T>) |
Выполняет поиск любого значения, отличного от указанного |
ContainsAnyExcept<T>(ReadOnlySpan<T>, ReadOnlySpan<T>) |
Выполняет поиск любого значения, отличного от указанного |
ContainsAnyExceptInRange<T>(ReadOnlySpan<T>, T, T) |
Ищет любое значение за пределами диапазона между |
ContainsAnyInRange<T>(ReadOnlySpan<T>, T, T) |
Ищет любое значение в диапазоне между |
Count<T>(ReadOnlySpan<T>, T) |
Подсчитывает количество указанных |
Count<T>(ReadOnlySpan<T>, ReadOnlySpan<T>) |
Подсчитывает количество |
EndsWith<T>(ReadOnlySpan<T>, T) |
Определяет, отображается ли указанное значение в конце диапазона. |
EndsWith<T>(ReadOnlySpan<T>, ReadOnlySpan<T>) |
Определяет, отображается ли указанная последовательность в конце диапазона только для чтения. |
IndexOf<T>(ReadOnlySpan<T>, T) |
Выполняет поиск указанного значения и возвращает индекс первого вхождения. Значения сравниваются с помощью IEquatable{T}. Equals(T). |
IndexOf<T>(ReadOnlySpan<T>, ReadOnlySpan<T>) |
Выполняет поиск указанной последовательности и возвращает индекс первого вхождения. Значения сравниваются с помощью IEquatable{T}. Equals(T). |
IndexOfAny<T>(ReadOnlySpan<T>, T, T) |
Выполняет поиск первого индекса любого из указанных значений, аналогичных вызову IndexOf несколько раз с помощью логического оператора OR. |
IndexOfAny<T>(ReadOnlySpan<T>, T, T, T) |
Выполняет поиск первого индекса любого из указанных значений, аналогичных вызову IndexOf несколько раз с помощью логического оператора OR. |
IndexOfAny<T>(ReadOnlySpan<T>, SearchValues<T>) |
Выполняет поиск первого индекса любого из указанных значений. |
IndexOfAny<T>(ReadOnlySpan<T>, ReadOnlySpan<T>) |
Выполняет поиск первого индекса любого из указанных значений, аналогичных вызову IndexOf несколько раз с помощью логического оператора OR. |
IndexOfAnyExcept<T>(ReadOnlySpan<T>, T) |
Выполняет поиск первого индекса любого значения, отличного от указанного |
IndexOfAnyExcept<T>(ReadOnlySpan<T>, T, T) |
Выполняет поиск первого индекса любого значения, отличного от указанного |
IndexOfAnyExcept<T>(ReadOnlySpan<T>, T, T, T) |
Выполняет поиск первого индекса любого значения, отличного от указанного |
IndexOfAnyExcept<T>(ReadOnlySpan<T>, SearchValues<T>) |
Выполняет поиск первого индекса любого значения, отличного от указанного |
IndexOfAnyExcept<T>(ReadOnlySpan<T>, ReadOnlySpan<T>) |
Выполняет поиск первого индекса любого значения, отличного от указанного |
IndexOfAnyExceptInRange<T>(ReadOnlySpan<T>, T, T) |
Выполняет поиск первого индекса любого значения вне диапазона между |
IndexOfAnyInRange<T>(ReadOnlySpan<T>, T, T) |
Выполняет поиск первого индекса любого значения в диапазоне между |
LastIndexOf<T>(ReadOnlySpan<T>, T) |
Выполняет поиск указанного значения и возвращает индекс последнего вхождения. Значения сравниваются с помощью IEquatable{T}. Equals(T). |
LastIndexOf<T>(ReadOnlySpan<T>, ReadOnlySpan<T>) |
Выполняет поиск указанной последовательности и возвращает индекс последнего вхождения. Значения сравниваются с помощью IEquatable{T}. Equals(T). |
LastIndexOfAny<T>(ReadOnlySpan<T>, T, T) |
Выполняет поиск последнего индекса любого из указанных значений, аналогичных вызову LastIndexOf несколько раз с логическим оператором OR. |
LastIndexOfAny<T>(ReadOnlySpan<T>, T, T, T) |
Выполняет поиск последнего индекса любого из указанных значений, аналогичных вызову LastIndexOf несколько раз с логическим оператором OR. |
LastIndexOfAny<T>(ReadOnlySpan<T>, SearchValues<T>) |
Выполняет поиск последнего индекса любого из указанных значений. |
LastIndexOfAny<T>(ReadOnlySpan<T>, ReadOnlySpan<T>) |
Выполняет поиск последнего индекса любого из указанных значений, аналогичных вызову LastIndexOf несколько раз с логическим оператором OR. |
LastIndexOfAnyExcept<T>(ReadOnlySpan<T>, T) |
Выполняет поиск последнего индекса любого значения, отличного от указанного |
LastIndexOfAnyExcept<T>(ReadOnlySpan<T>, T, T) |
Выполняет поиск последнего индекса любого значения, отличного от указанного |
LastIndexOfAnyExcept<T>(ReadOnlySpan<T>, T, T, T) |
Выполняет поиск последнего индекса любого значения, отличного от указанного |
LastIndexOfAnyExcept<T>(ReadOnlySpan<T>, SearchValues<T>) |
Выполняет поиск последнего индекса любого значения, отличного от указанного |
LastIndexOfAnyExcept<T>(ReadOnlySpan<T>, ReadOnlySpan<T>) |
Выполняет поиск последнего индекса любого значения, отличного от указанного |
LastIndexOfAnyExceptInRange<T>(ReadOnlySpan<T>, T, T) |
Ищет последний индекс любого значения вне диапазона между |
LastIndexOfAnyInRange<T>(ReadOnlySpan<T>, T, T) |
Ищет последний индекс любого значения в диапазоне от |
Overlaps<T>(ReadOnlySpan<T>, ReadOnlySpan<T>) |
Определяет, перекрываются ли две последовательности только для чтения в памяти. |
Overlaps<T>(ReadOnlySpan<T>, ReadOnlySpan<T>, Int32) |
Определяет, перекрываются ли две последовательности только для чтения в памяти и выводит смещение элемента. |
Replace<T>(ReadOnlySpan<T>, Span<T>, T, T) |
Копирует |
SequenceCompareTo<T>(ReadOnlySpan<T>, ReadOnlySpan<T>) |
Определяет относительный порядок двух последовательностей только для чтения, сравнивая их элементы с помощью IComparable{T}. CompareTo(T). |
SequenceEqual<T>(ReadOnlySpan<T>, ReadOnlySpan<T>) |
Определяет, равны ли две последовательности только для чтения, сравнивая элементы с помощью IEquatable{T}. Equals(T). |
SequenceEqual<T>(ReadOnlySpan<T>, ReadOnlySpan<T>, IEqualityComparer<T>) |
Определяет, равны ли две последовательности, сравнивая элементы с помощью IEqualityComparer<T>. |
Split<T>(ReadOnlySpan<T>, T) |
Предоставляет типобезопасное и безопасное для чтения представление непрерывной области произвольной памяти. |
Split<T>(ReadOnlySpan<T>, ReadOnlySpan<T>) |
Предоставляет типобезопасное и безопасное для чтения представление непрерывной области произвольной памяти. |
SplitAny<T>(ReadOnlySpan<T>, SearchValues<T>) |
Предоставляет типобезопасное и безопасное для чтения представление непрерывной области произвольной памяти. |
SplitAny<T>(ReadOnlySpan<T>, ReadOnlySpan<T>) |
Предоставляет типобезопасное и безопасное для чтения представление непрерывной области произвольной памяти. |
StartsWith<T>(ReadOnlySpan<T>, T) |
Определяет, отображается ли указанное значение в начале диапазона. |
StartsWith<T>(ReadOnlySpan<T>, ReadOnlySpan<T>) |
Определяет, отображается ли указанная последовательность в начале диапазона только для чтения. |
Trim<T>(ReadOnlySpan<T>, T) |
Удаляет все начальные и конечные вхождения указанного элемента из диапазона только для чтения. |
Trim<T>(ReadOnlySpan<T>, ReadOnlySpan<T>) |
Удаляет все начальные и конечные вхождения набора элементов, указанных в диапазоне только для чтения, из диапазона только для чтения. |
TrimEnd<T>(ReadOnlySpan<T>, T) |
Удаляет все конечные вхождения указанного элемента из диапазона только для чтения. |
TrimEnd<T>(ReadOnlySpan<T>, ReadOnlySpan<T>) |
Удаляет все конечные вхождения набора элементов, указанных в диапазоне только для чтения, из диапазона только для чтения. |
TrimStart<T>(ReadOnlySpan<T>, T) |
Удаляет все начальные вхождения указанного элемента из диапазона. |
TrimStart<T>(ReadOnlySpan<T>, ReadOnlySpan<T>) |
Удаляет все начальные вхождения набора элементов, указанных в диапазоне только для чтения, из диапазона. |
Применяется к
См. также раздел
- типы, связанные с памятью и диапазоном,
- <памяти T> и рекомендации по использованию><>