Этот метод возвращает значение больше нуля, если х больше у; значение меньше нуля, если х меньше у; и, наконец, нулевое значение, если оба значения равны.
Интерфейс IComparer<T> находится в пространстве имен System. Collections. Generic. В нем определяется метод Compare (), общая форма которого приведена ниже.
Int Compare(Т х, Т у)
Он действует таким же образом, как и его необобщенный аналог, возвращая значение больше нуля, если х больше у значение меньше нуля, если х меньше у и, наконец, нулевое значение, если оба значения равны. Преимущество интерфейса IComparer<T> заключается в том, что он обеспечивает типовую безопасность. Ведь в этом случае тип обрабатываемых данных указывается явным образрм, а следовательно, никакого приведения типов не требуется.
В последующих разделах демонстрируется ряд наиболее распространенных операций с массивами.
Таблица 21.11. Свойства, определенные в классе Array
Свойство
Назначение
public bool IsFixedSize { get; }
public bool IsReadOnly { get; }
public bool
IsSynchronized { get; }
Доступно только для чтения. Принимает логическое значение true, если массив имеет фиксированный размер, и логическое значение false, если массив может изменять его динамически
Доступно только для чтения. Принимает логическое значение true, если объект класса Array предназначен только для чтения, а иначе — логическое значение false. Для массивов это свойство всегда имеет логическое значение true Доступно только для чтения. Принимает логическое значение true, если массив можно безопасно использовать в многопоточной среде, а иначе — логическое значение false. Для массивов это свойство всегда имеет логическое значение true
Свойство
Назначение '
public int Length {
Доступно только для чтения. Имеет тип int и содержит ко
get; }
личество элементов в массиве
Public long LongLength
Доступно только для чтения. Имеет тип long и содержит
{ get; }
количество элементов в массиве
public int Rank { get; }
Доступно только для чтения. Содержит размерность массива
Public object SyncRoot
Доступно только для чтения. Содержит объект, предназна
{ get; }
ченный для синхронизации доступа к массиву
Таблица 21.12. Методы, определенные в классе Array
Метод
Назначение
Public static
Возвращает доступную только для чтения коллек
ReadOnlyCollection<T>
цию, которая включает в себя массив, определяе
AsReadOnly<T>(Т [] array)
мый параметром array
Public static int
Осуществляет поиск значения value в массиве
BinarySearch(Array
array,
array. Возвращает индекс первого вхождения
object value)
искомого значения. Если оно не найдено, возвращает отрицательное значение. Массив array должен быть отсортированным и одномерным
Public static int
Осуществляет поиск значения value в массиве
BinarySearch<T>(T[]
array,
array. Возвращает индекс первого вхождения
T value)
искомого значения. Если оно не найдено, возвращает отрицательное значение. Массив array должен быть отсортированным и одномерным
Public static int
Осуществляет поиск значения value в масси
BinarySearch(Array
array,
ве, определяемом параметром array, исполь
object value, IComparer
зуя способ сравнения, задаваемый параметром
comparer)
comparer. Возвращает индекс первого вхождения искомого значения. Если оно не найдено, возвращает отрицательное значение. Массив array должен быть отсортированным и одномерным
Public static int
Осуществляет поиск значения value в массиве
BinarySearch<T> (T [ ]
array,
array, используя способ сравнения, задаваемый
T value, IComparer<T>
параметром comparer. Возвращает индекс перво
comparer)
го вхождения искомого значения. Если оно не найдено, возвращает отрицательное значение. Массив array должен быть отсортированным и одномерным
Public static int
Осуществляет поиск значения value в части мас
BinarySearch(Array
array,
сива array. Поиск начинается с индекса, зада
int index, int length,
ваемого параметром index, и охватывает число
object value)
элементов, определяемых параметром length. Возвращает индекс первого вхождения искомого значения. Если оно не найдено, возвращает отрицательное значение. Массив array должен быть отсортированным и одномерным
Метод
Назначение
public static int
Осуществляет поиск значения value в части мас
BinarySearch<T>(T[] array,
сива array. Поиск начинается с индекса, зада
int index, int length, T
ваемого параметром index, и охватывает число
value)
элементов, определяемых параметром length. Возвращает индекс первого вхождения искомого значения. Если оно не найдено, возвращает отрицательное значение. Массив array должен быть отсортированным и одномерным
public static int
Осуществляет поиск значения value в части мас
BinarySearch(Array array,
сива array, используя способ сравнения, опреде
int index, int length,
ляемый параметром comparer. Поиск начинается
object value, IComparer
с индекса, задаваемого параметром index, и охва
comparer)
тывает число элементов, определяемых параметром length. Возвращает индекс первого вхождения искомого значения. Если оно не найдено, возвращает отрицательное значение. Массив array должен быть отсортированным и одномерным
public static int
Осуществляет поиск значения value в части мас
BinarySearch<T>(T [] array,
сива array, используя способ сравнения, опреде
int index, int length,
ляемый параметром comparer. Поиск начинается
T value, Icomparer<T>
с индекса, задаваемого параметром index, и охва
comparer)
тывает число элементов, определяемых параметром length. Возвращает индекс первого вхождения искомого значения. Если оно не найдено, возвращает отрицательное значение. Массив array должен быть отсортированным и одномерным
public static void
Устанавливает заданные элементы массива array
Clear(Array array, int
равными нулю, пустому значению null или логи
index, int length)
ческому значению false в зависимости оттипэ элемента: значения, ссылочного или логического. Подмножество элементов, подлежащих обнулению, начинается с индекса, задаваемого параметром index, и включает в себя число элементов, определяемых параметром length
public object Clone ()
Возвращает копию вызывающего массива. Эта копия ссылается на те же элементы, что и оригинал, поэтому она называется “неполной". Таким образом, изменения, вносимые в элементы, влияют на оба массива, поскольку и в том и в другом используются одни и те же элементы
public static void
Копирует число элементов, задаваемых па
ConstrainedCopy(Array
раметром length, из исходного массива
sourceArray, int sourcelndex,
sourceArray, начиная с элемента, указывае
Array destinationArray, int
мого по индексу sourcelndex, в целевой мас
destinationlndex, int length)
сив destinationArray, начиная с элемента,
_ Продолжение табл. 21.12
Метод
Назначение
указываемого по индексу destinationlndex. Если
оба массива имеют одинаковый ссылочный тип, то метод ConstrainedCopy () создает “неполную копию", в результате чего оба массива будут ссылаться на одни и те же элементы. Если же во время копирования возникает ошибка, то содержимое целевого массива destinationAr ray остается прежним
public static TTo [ ]
Преобразует массив array из типа Tlnput в тип
ConvertА11<ТInput,
TOutput и возвращает получающийся в итоге
TTo>(TFrom[] array,
массив. Исходный массив остается прежним. Пре
Converter<TOutput, TTo>
образование выполняется преобразователем, за
converter)
даваемым параметром converter
public static void
Копирует число элементов, задаваемых параметром
Copy(Array sourceArray,
length, из исходного массива sourceArray в це
Array destinationArray,
int
левой массив destinationArray, начиная с пер
length)
вого элемента массива. Если оба массива имеют одинаковый ссылочный тип, то метод Сору () создает “неполную копию", в результате чего оба массива будут ссылаться на одни и те же элементы. Если же во время копирования возникает ошибка, то содержимое целевого массива destinationArray оказывается неопределенным
public static void
Копирует число элементов, задаваемых параметром
Copy(Array sourceArray,
length, из исходного массива sourceArray в це
Array destinationArray,
long
левой массив destinationArray, начиная с пер
length)
вого элемента массива. Если оба массива имеют одинаковый ссылочный тип, то метод Сору () создает “неполную копию”, в результате чего оба массива будут ссылаться на одни и те же элементы. Если же во время копирования возникает ошибка, то содержимое целевого массива destinationArray оказывается неопределенным
public static void
Копирует число элементов, задаваемых параме
Copy(Array sourceArray,
тром length, из исходного массива sourceArray,
int sourcelndex, Array
начиная с элемента, указываемого по индексу
destinationArray, int
sourceArray [ sourcelndex], в целевой массив
destinationlndex, int
destinationArray, начиная с элемента, указы
length)
ваемого по индексу destinationAr ray [destinationlndex]. Если оба массива имеют одинаковый ссылочный тип, то метод Сору () создает “неполную копию”, в результате чего оба массива будут ссылаться на одни и те же элементы. Если же во время копирования возникает ошибка, то содержимое целевого массива destinationArray оказывается неопределенным
Метод
Назначение
public static void
Копирует число элементов, задаваемых параме
Copy(Array sourceArray,
тром length, из исходного массива sourceArray,
long sourcelndex, Array
начиная с элемента, указываемого по индексу
destinationArray, long
sourceArray [source Index], в целевой массив
destinationlndex, long
destinationArray, начиная с элемента, указы
length)
ваемого по индексу destinationArray [destinationlndex]. Если оба массива имеют одинаковый ссылочный тип, то метод Сору () создает “неполную копию”, в результате чего оба массива будут ссылаться на одни и те же элементы. Если же во время копирования возникает ошибка, то содержимое целевого массива destinationArray оказывается неопределенным
public void CopyTo(Array
Копирует элементы вызывающего массива в це
array, int index)
левой массив array, начиная с элемента, указываемого по индексу array [index]. Если же во время копирования возникает ошибка, то содержимое целевого массива array оказывается неопределенным
public void CopyTo(Array
Копирует элементы вызывающего массива в це
array, long index)
левой массив array, начиная с элемента, указываемого по индексу array [index]. Если же во время копирования возникает ошибка, то содержимое целевого массива array оказывается неопределенным
public static Array
Возвращает ссылку на одномерный массив, кото
Createlnstance(Type
рый содержит число элементов типа elementType,
elementType, int length)
определяемое параметром length
public static Array
Возвращает ссылку на двумерный массив разме
Createlnstance(Type
ром lengthl*length2. Каждый элемент этого
elementType, int lengthl,
массива имеет тип elementType
int length2)
public static Array
^ Возвращает ссылку на трехмерный массив разме
Createlnstance(Type
ром lengthl* length2* length3. Каждый эле
elementType, int lengthl,
мент этого массива имеет тип elementType
int length2, int length3)
public static Array
Возвращает ссылку на многомерный массив, раз
Createlnstance(Type
мерность которого задается в массиве lengths.
elementType, params int[]
Каждый элемент этого массива имеет тип
lengths)
elementType
public static Array
Возвращает ссылку на многомерный массив, раз
Createlnstance(Type
мерность которого задается в массиве lengths.
elementType, params long[]
Каждый элемент этого массива имеет тип
lengths)
elementType
_ Продолжение табл. 21.12
Метод
Назначение
Public static Array
Возвращает ссылку на многомерный массив, раз
Createlnstance(Type
мерность которого задается в массиве lengths.
elementType, int []lengths,
Каждый элемент этого массива имеет тип
int[] lowerBounds)
elementType. Начальный индекс каждого измерения задается в массиве lowerBounds. Таким образом, этот метод позволяет создавать массивы, которые начинаются с некоторого индекса, отличного от нуля
Public static bool
Возвращает логическое значение true, если мас
Exists<T>(T[] array,
сив array содержит хотя бы один элемент, удо
Predicate<T> match)
влетворяющий условию предиката, задаваемого параметром match, а иначе возвращает логическое значение false
public static T Find<T>(T[]
Возвращает первый элемент массива array, удо
array , Predicate<T> match)
влетворяющий условию предиката, задаваемого параметром’ match, а иначе возвращает значение типа default (Т)
public static T[]
Возвращает все элементы массива array, удо
FindAll<T>(T[] array,
влетворяющие условию предиката, задаваемого
Predicate<T> match)
параметром match, а иначе возвращает массив нулевой длины
Public static int
Возвращает индекс первого элемента массива
FindIndex<T>(T[] array,
array, удовлетворяющего условию предиката, за
Predicate<T> match)
даваемого параметром match, иначе возвращает значение -1
Public static int
Возвращает индекс первого элемента масси
FindIndex<T>(T[] array, int
ва array, удовлетворяющего убловию предика
startlndex, Predicate<T>
та, задаваемого параметром match. Поиск на
match)
чинается с элемента, указываемого по индексу array [ start Index]. Если ни один из элементов, удовлетворяющих данному условию, не найден, то возвращается значение -1
Public static int
Возвращает индекс первого элемента масси
FindIndex<T>(T[] array,
ва array, удовлетворяющего условию предика
int startlndex, int count,
та, задаваемого параметром match. Поиск на
Predicate<T> match)
чинается с элемента, указываемого по индексу array [startlndex], и продолжается среди числа элементов, определяемых параметром count. Если ни один из элементов, удовлетворяющих данному условию, не найден, то возвращается значение -1
Public static T
Возвращает последний элемент массива array,
FindLast<T>(T[] array,
удовлетворяющий условию предиката, задаваемо
Predicate<T> match)
го параметром match, иначе возвращает значение типа default (Т)
Метод
Назначение
Public static int
Возвращает индекс последнего элемента массива
FindLastIndex<T>(T []
array,
array, удовлетворяющего условию предиката, за
. Predicate<T> match )
даваемого параметром match, иначе возвращает значение -1
Public static int
Возвращает индекс последнего элемента массива
FindLastIndex<T>(T []
array,
array, удовлетворяющего условию предиката, за
int startlndex, Predicate<T>
даваемого параметром match. Поиск начинается
match)
в обратном порядке с элемента, указываемого по индексу array [startlndex], и оканчивается на элементе array [ 0]. Если ни один из элементов, удовлетворяющих данному условию, не найден, то возвращается значение -1
Public static int
Возвращает индекс последнего элемента массива
FindLastIndex<T>(T []
array,
array, удовлетворяющего условию предиката, за
int startlndex , int
count,
даваемого параметром v. Поиск начинается в об
Predicate<T> match)
ратном порядке с элемента, указываемого по индексу array[start], и продолжается среди числа элементов, определяемых параметром count. Если ни один из элементов, удовлетворяющих данному условию, не найден, то возвращается значение -1
Public static void
Применяет метод, задаваемый параметром
ForEach<T>(T[] array,
action, к каждому элементу массива array
Action<T> action)
Public IEnumerator
Возвращает перечислительный объект для масси
GetEnumerator ()
ва. Перечислители позволяют опрашивать массив в цикле. Боле подробно перечислители описываются в главе 25
Public override int
Возвращает хеш-код для вызывающего объекта
GetHashCode ()
Public int GetLength(int
Возвращает длину заданного измерения массива.
dimension)
Отсчет измерений начинается с нуля, поэтому для получения длины первого измерения необходимо передать данному методу значение 0 параметра dimension, для получения длины второго измерения — значение 1 и т.д.