Полное руководство. С# 4.0
Шрифт:
В структуре Char определены также следующие поля. public const char MaxValue public const char MinValue
Кроме того, в структуре Char реализуются следующие интерфейсы: IComparable, IComparable<char>, IConvertible и IEquatable<char>.
Таблица 21.9. Методы, определенные в структуре Char Метод Назначение public int CompareTo(char value) Сравнивает символ в вызывающем объекте с символом value. Возвращает нуль, если сравниваемые символы равны; отрицательное значение, если вызывающий объект имеет меньшее значение; и, наконец, положительное значение, если вызывающий объект имеет большее значение public int CompareTo(object value) Сравнивает символ в вызывающем объекте с символом value. Возвращает нуль, если сравниваемые символы равны; отрицательное значение, если вызывающий объект имеет меньшее значение; и, наконец, положительное значение, если вызывающий объект имеет большее значение public static string ConvertFromUtf32(int utf32) Преобразует кодовую точку уникода, представленную параметром utf32 в формате UTF-32, в символьную строку формата UTF-16 и возвращает полученный результат pubic static int ConvertToUtf32 (char highSurrogate, char lowSurrogate) Преобразует старший и младший суррогаты, представленные параметрами highSurrogate и lowSurrogate в формате UTF-16, в кодовую точку формата UTF-32 и возвращает полученный результат pubic static int ConvertToUtf32(string s, int index) Преобразует пару суррогатов формата UTF-16, доступных из символьной строки по индексу s[index], в кодовую точку формата UTF-32 и возвращает полученный результат public bool Equals(char obj) Возвращает логическое значение true, если значение вызывающего объекта равно значению obj public override bool Equals(object obj) Возвращает логическое значение true, если значение вызывающего объекта равно значению obj public override int GetHashCode Возвращает хеш-код для вызывающего объекта public static double GetNumericValue(char c) Возвращает числовое значение символа с, если он обозначает цифру. В противном случае возвращает -1 public static double GetNumericValue(string s, int index) Возвращает числовое значение символа, доступного из строки по индексу s[index], если он обозначает цифру. В противном случае возвращает -1 public TypeCode GetTypeCode Возвращает значение из перечисления TypeCode для структуры Char, т.е. TypeCode.Char public static UnicodeCategory GetUnicodeCategory(char c) Возвращает значение из перечисления UnicodeCategory для символа с. Перечисление UnicodeCategory определено в пространстве имен System.Globalization и распределяет символы уникода по категориям public static UnicodeCategory GetUnicodeCategory(string s, int index) Возвращает значение из перечисления UnicodeCategory для символа, доступного из строки по индексу s[index]. Перечисление UnicodeCategory определено в пространстве имен System.Globalization и распределяет символы уникода по категориям public static bool IsControl(char c) Возвращает логическое значение true, если символ с является управляющим, иначе возвращает логическое значение false public static bool IsControl(string s, int index) Возвращает логическое значение true, если символ, доступный из строки по индексу s[index], является управляющим, иначе возвращает логическое значение false public static bool IsDigit(char c) Возвращает логическое значение true, если символ с обозначает цифру, а иначе возвращает логическое значение false public static bool IsDigit(string s, int index) Возвращает логическое значение true, если символ, доступный из строки по индексу s[index], обозначает цифру, а иначе возвращает логическое значение false public static bool IsHighSurrogate(char c) Возвращает логическое значение true, если символьное значение с является действительным старшим суррогатом формата UTF-32, а иначе возвращает логическое значение false public static bool IsHighSurrogate(string s, int Index) Возвращает логическое значение true, если символьное значение, доступное из строки по индексу s[index], является действительным старшим суррогатом формата UTF-32, а иначе возвращает логическое значение false public static bool IsLetter(char c) Возвращает логическое значение true, если символ с обозначает букву алфавита, а иначе возвращает логическое значение false public static bool IsLetter(string s, int index) Возвращает логическое значение true,
Ниже приведен пример программы, в которой демонстрируется применение не скольких методов, определенных в структуре Char. // Продемонстрировать применение нескольких методов, // определенных в структуре Char. using System; using System.Globalization; class CharDemo { static void Main { string str = "Это простой тест. $23"; int i; for(i=0; i < str.Length; i++) { Console.Write(str[i] + " является"); if(Char.isDigit(str[i])) Console.Write(" цифрой"); if(Char.IsLetter(str[i])) Console.Write(" буквой"); if(Char.IsLower(str[i])) Console.Write(" строчной"); if(Char.IsUpper(str[i])) Console.Write(" прописной"); if(Char.IsSymbol(str [i])) Console.Write(" символическим знаком"); if(Char.IsSeparator(str[i])) Console.Write(" разделительным"); if(Char.IsWhiteSpace(str[i])) Console.Write(" пробелом"); if(Char.IsPunctuation(str[i])) Console.Write(" знаком препинания"); Console.WriteLine; } Console.WriteLine("Исходная строка: " + str); // Преобразовать в прописные буквы. string newstr = ""; for(i=0; i < str.Length; i++) newstr += Char.ToUpper(str[i], CultureInfo.CurrentCulture); Console.WriteLine("После преобразования: " + newstr); } }
Эта программа дает следующий результат. Э является буквой прописной т является буквой строчной о является буквой строчной является разделительным пробелом п является буквой строчной р является буквой строчной о является буквой строчной с является буквой строчной т является буквой строчной о является буквой строчной й является буквой строчной является разделительным пробелом т является буквой строчной е является буквой строчной с является буквой строчной т является буквой строчной . является знаком препинания является разделительным пробелом $ является символическим знаком 2 является цифрой 3 является цифрой Исходная строка: Это простой тест. $23 После преобразования: ЭТО ПРОСТОЙ ТЕСТ. $23 Структура Boolean
В структуре Boolean поддерживаются данные типа bool. Методы, определенные в этой структуре, перечислены в табл. 21.10. Кроме того, в ней определены следующие поля. public static readonly string FalseString public static readonly string TrueString
В этих полях логические значения true и false содержатся в удобочитае мой форме. Так, если вывести содержимое поля FalseString с помощью метода WriteLine, то на экране появится строка "False".
В структуре Boolean реализованы следующие интерфейсы: IComparable, IComparable<bool>, IConvertible и IEquatable<bool>.
Таблица 21.10. Методы, определенные в структуре Boolean Метод Назначение public int CompareTo(bool value) Сравнивает логическое значение вызывающего объекта со значением параметра value. Возвращает нуль, если сравниваемые значения равны; отрицательное значение, если вызывающий объект имеет логическое значение false, а параметр value — логическое значение true; и, наконец, положительное значение, если вызывающий объект имеет логическое значение true, а параметр value — логическое значение false public int CompareTo(object obj) Сравнивает логическое значение вызывающего объекта со значением параметра obj. Возвращает нуль, если сравниваемые значения равны; отрицательное значение, если вызывающий объект имеет логическое значение false, а параметр obj — логическое значение true; и, наконец, положительное значение, если вызывающий объект имеет логическое значение true, а параметр obj — логическое значение false public bool Equals(bool obj) Возвращает логическое значение true, если значение вызывающего объекта равно значению параметра obj public override bool Equals(object obj) Возвращает логическое значение true, если значение вызывающего объекта равно значению параметра obj public override int GetHashCode Возвращает хеш-код для вызывающего объекта public TypeCode GetTypeCode Возвращает значение перечисления TypeCode для структуры Boolean, т.е. TypeCode.Boolean public static bool Parse(string s) Возвращает эквивалент типа bool символьной строки s. Если строка s не содержит ни поле Boolean. TrueString, ни поле Boolean.FalseString, то генерируется исключение FormatException, независимо от того, какими буквами набрано содержимое строки: прописными или строчными public override string ToString Возвращает строковое представление значения вызывающего объекта, которое должно быть либо значением поля TrueString, либо значением поля FalseString public string ToString(IFormatProvider provider) Возвращает строковое представление значения вызывающего объекта, которое должно быть либо значением поля TrueString, либо значением поля FalseString. При этом параметр provider игнорируется public static bool TryParse(string s, out bool result) Предпринимает попытку преобразовать символ из строки s в его эквивалентное значение типа bool. При успешной попытке это значение сохраняется в параметре result и возвращается логическое значение true. Если же строка s не содержит ни поле Boolean. TrueString, ни поле Boolean.FalseString, то возвращается логическое значение false, независимо от того, какими буквами набрано содержимое строки: прописными или строчными, в отличие от метода Parse, который генерирует исключение в аналогичной ситуации Класс Array
Класс Array относится к числу наиболее часто используемых в пространстве имен System. Он является базовым классом для всех массивов в С#. Следовательно, его ме тоды можно применять к массивам любого встроенного в C# типа или же к массивам определяемого пользователем типа. Свойства, определенные в классе Array, перечис лены в табл. 21.11, а методы — в табл. 21.12.
В классе Array реализуются следующие интерфейсы: ICloneable, ICollection, IEnumerable, IStructuralComparable, IStructuralEquatable, а также IList. Все интерфейсы, кроме ICloneable, определены в пространстве имен System. Collections, подробнее рассматриваемом в главе 25.
В ряде методов данного класса используется параметр типа IComparer или IComparer<T>. Интерфейс IComparer находится в пространстве имен System. Collections. В нем определяется метод Compare для сравнения значений двух объектов, как показано ниже. int Compare(object х, object у)
Этот метод возвращает значение больше нуля, если х больше у; значение меньше нудя, если х меньше у; и, наконец, нулевое значение, если оба значения равны. Интерфейс IComparer находится в пространстве имен System.Collections. Generic. В нем определяется метод Compare, общая форма которого приведена ниже. int Compare(Т х, Т у)
Он действует таким же образом, как и его необобщенный аналог, возвращая значе ние больше нуля, если х больше у значение меньше нуля, если х меньше у, и, наконец, нулевое значение, если оба значения равны. Преимущество интерфейса IComparer заключается в том, что он обеспечивает типовую безопасность. Ведь в этом случае тип обрабатываемых данных указывается явным образом, а следовательно, никакого при ведения типов не требуется.
В последующих разделах демонстрируется ряд наиболее распространенных опера ций с массивами.
Таблица 21.11. Свойства, определенные в классе Array Свойство Назначение public bool IsFixedSize { get; } Доступно только для чтения. Принимает логическое значение true, если массив имеет фиксированный размер, и логическое значение false, если массив может изменять его динамически public bool IsReadOnly { get; } Доступно только для чтения. Принимает логическое значение true, если объект класса Array предназначен только для чтения, а иначе — логическое значение false. Для массивов это свойство всегда имеет логическое значение true public bool IsSynchronized { get; } Доступно только для чтения. Принимает логическое значение true, если массив можно безопасно использовать в многопоточной среде, а иначе — логическое значение false. Для массивов это свойство всегда имеет логическое значение true public int Length { get; } Доступно только для чтения. Имеет тип int и содержит количество элементов в массиве public long LongLength { get; } Доступно только для чтения. Имеет тип long и содержит количество элементов в массиве public int Rank { get; } Доступно только для чтения. Содержит размерность массива public object SyncRoot { get; } Доступно только для чтения. Содержит объект, предназначенный для синхронизации доступа к массиву
Таблица 21.12. Методы, определенные в классе Array Метод Назначение public static ReadOnlyCollection<T> AsReadOnly<T>(T[] array) Возвращает доступную только для чтения коллекцию, которая включает в себя массив, определяемый параметром array public static int BinarySearch(Array array, object value) Осуществляет поиск значения value в массиве array. Возвращает индекс первого вхождения искомого значения. Если оно не найдено, возвращает отрицательное значение. Массив array должен быть отсортированным и одномерным public static int BinarySearch<T>(T[] array, T value) Осуществляет поиск значения value в массиве array. Возвращает индекс первого вхождения искомого значения. Если оно не найдено, возвращает отрицательное значение. Массив array должен быть отсортированным и одномерным public static int BinarySearch(Array array, object value, IComparer comparer) Осуществляет поиск значения value в массиве, определяемом параметром array, используя способ сравнения, задаваемый параметром comparer. Возвращает индекс первого вхождения искомого значения. Если оно не найдено, возвращает отрицательное значение. Массив array должен быть отсортированным и одномерным public static int BinarySearch<T>(T[] array, T value, IComparer<T> comparer) Осуществляет поиск значения value в массиве array, используя способ сравнения, задаваемый параметром comparer. Возвращает индекс первого вхождения искомого значения. Если оно не найдено, возвращает отрицательное значение. Массив array должен быть отсортированным и одномерным public static int BinarySearch(Array array, int index, int length, object value) Осуществляет поиск значения value в части массива array. Поиск начинается с индекса, задаваемого параметром index, и охватывает число элементов, определяемых параметром length. Возвращает индекс первого вхождения искомого значения. Если оно не найдено, возвращает отрицательное значение. Массив array должен быть отсортированным и одномерным public static int BinarySearch<T>(T[] array, int index, int length, T value) Осуществляет поиск значения value в части массива array. Поиск начинается с индекса, задаваемого параметром index, и охватывает число элементов, определяемых параметром length. Возвращает индекс первого вхождения искомого значения. Если оно не найдено, возвращает отрицательное значение. Массив array должен быть отсортированным и одномерным public static int BinarySearch(Array array, int index, int length, object value, IComparer comparer) Осуществляет поиск значения value в части массива array, используя способ сравнения, определяемый параметром comparer. Поиск начинается с индекса, задаваемого параметром index, и охватывает число элементов, определяемых параметром length. Возвращает индекс первого вхождения искомого значения. Если оно не найдено, возвращает отрицательное значение. Массив array должен быть отсортированным и одномерным public static int BinarySearch<T>(T [] array, int index, int length, T value, Icomparer<T> comparer) Осуществляет поиск значения value в части массива array, используя способ сравнения, определяемый параметром comparer. Поиск начинается с индекса, задаваемого параметром index, и охватывает число элементов, определяемых параметром length. Возвращает индекс первого вхождения искомого значения. Если оно не найдено, возвращает отрицательное значение. Массив array должен быть отсортированным и одномерным public static void Clear(Array array, int index, int length) Устанавливает заданные элементы массива array равными нулю, пустому значению null или логическому значению false в зависимости от типа элемента: значения, ссылочного или логического. Подмножество элементов, подлежащих обнулению, начинается с индекса, задаваемого параметром index, и включает в себя число элементов, определяемых параметром length public object Clone Возвращает копию вызывающего массива. Эта копия ссылается на те же элементы, что и оригинал, поэтому она называется “неполной". Таким образом, изменения, вносимые в элементы, влияют на оба массива, поскольку и в том и в другом используются одни и те же элементы public static void ConstrainedCopy(Array sourceArray, int sourceIndex, Array destinationArray, int destinationIndex, int length) Копирует число элементов, задаваемых параметром length, из исходного массива sourceArray, начиная с элемента, указываемого по индексу sourceIndex, в целевой массив destinationArray, начиная с элемента, указываемого по индексу destinationIndex. Если оба массива имеют одинаковый ссылочный тип, то метод ConstrainedCopy создает “неполную копию”, в результате чего оба массива будут ссылаться на одни и те же элементы. Если же во время копирования возникает ошибка, то содержимое целевого массива destinationArray остается прежним public static ТТо[] ConvertAll<TInput, ТТо>(TFrom[] array, Converter<TOutput, TTo> converter) Преобразует массив array из типа TInput в тип TOutput и возвращает получающийся в итоге массив. Исходный массив остается прежним. Преобразование выполняется преобразователем, задаваемым параметром converter public static void Copy(Array sourceArray, Array destinationArray, int length) Копирует число элементов, задаваемых параметром length, из исходного массива sourceArray в целевой массив destinationArray, начиная с первого элемента массива. Если оба массива имеют одинаковый ссылочный тип, то метод Сору создает "неполную копию”, в результате чего оба массива будут ссылаться на одни и те же элементы. Если же во время копирования возникает ошибка, то содержимое целевого массива destinationArray оказывается неопределенным public static void Copy(Array sourceArray, Array destinationArray, long length) Копирует число элементов, задаваемых параметром length, из исходного массива sourceArray в целевой массив destinationArray, начиная с первого элемента массива. Если оба массива имеют одинаковый ссылочный тип, то метод Сору создает "неполную копию”, в результате чего оба массива будут ссылаться на одни и те же элементы. Если же во время копирования возникает ошибка, то содержимое целевого массива destinationArray оказывается неопределенным public static void Copy(Array sourceArray, int sourceIndex, Array destinationArray, int destinationlndex, int length) Копирует число элементов, задаваемых параметром length, из исходного массива sourceArray, начиная с элемента, указываемого по индексу sourceArray[sourceIndex], в целевой массив destinationArray, начиная с элемента, указываемого по индексу destinationArray[destinationIndex]. Если оба массива имеют одинаковый ссылочный тип, то метод Сору создает “неполную копию", в результате чего оба массива будут ссылаться на одни и те же элементы. Если же во время копирования возникает ошибка, то содержимое целевого массива destinationArray оказывается неопределенным public static void Copy(Array sourceArray, long sourceIndex, Array destinationArray, long destinationIndex, long length) Копирует число элементов, задаваемых параметром length, из исходного массива sourceArray, начиная с элемента, указываемого по индексу sourceArray[sourceIndex], в целевой массив destinationArray, начиная с элемента, указываемого по индексу destinationArray[destinationIndex]. Если оба массива имеют одинаковый ссылочный тип, то метод Сору создает "неполную копию”, в результате чего оба массива будут ссылаться на одни и те же элементы. Если же во время копирования возникает ошибка, то содержимое целевого массива 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 CreateInstance(Type elementType, int length) Возвращает ссылку на одномерный массив, который содержит число элементов типа elementType, определяемое параметром length public static Array Createlnstance(Type elementType, int length1, int length2) Возвращает ссылку на двумерный массив размером length1xlength2. Каждый элемент этого массива имеет тип elementType public static Array Createlnstance(Type elementType, int length1, int length2, int length3) Возвращает ссылку на трехмерный массив размером length1xlength2xlength3. Каждый элемент этого массива имеет тип elementType public static Array Createlnstance(Type elementType, params int[] lengths) Возвращает ссылку на многомерный массив, размерность которого задается в массиве lengths. Каждый элемент этого массива имеет тип elementType public static Array Createlnstance(Type elementType, params long[] lengths) Возвращает ссылку на многомерный массив, размерность которого задается в массиве lengths. Каждый элемент этого массива имеет тип elementType public static Array Createlnstance(Type elementType, int[]lengths, int[] lowerBounds) Возвращает ссылку на многомерный массив, размерность которого задается в массиве lengths. Каждый элемент этого массива имеет тип elementType. Начальный индекс каждого измерения задается в массиве lowerBounds. Таким образом, этот метод позволяет создавать массивы, которые начинаются с некоторого индекса, отличного от нуля public static bool Exists<T>(T[] array, Predicate<T> match) Возвращает логическое значение true, если массив array содержит хотя бы один элемент, удовлетворяющий условию предиката, задаваемого параметром match, а иначе возвращает логическое значение false public static T Find<T>(T[] array, Predicate<T> match) Возвращает первый элемент массива array, удовлетворяющий условию предиката, задаваемого параметром match, а иначе возвращает значение типа default(Т) public static T[] FindAll<T>(T[] array, Predicate<T> match) Возвращает все элементы массива array, удовлетворяющие условию предиката, задаваемого параметром match, а иначе возвращает массив нулевой длины public static int FindIndex<T>(T[] array, Predicate<T> match) Возвращает индекс первого элемента массива array, удовлетворяющего условию предиката, задаваемого параметром match, иначе возвращает значение -1 public static int FindIndex<T>(T[]array, int startIndex, Predicate<T> match) Возвращает индекс первого элемента массива array, удовлетворяющего условию предиката, задаваемого параметром match. Поиск начинается с элемента, указываемого по индексу array[startIndex]. Если ни один из элементов, удовлетворяющих данному условию, не найден, то возвращается значение -1 public static int FindIndex<T>(T[] array, int startlndex, int count, Predicate<T> match) Возвращает индекс первого элемента массива array, удовлетворяющего условию предиката, задаваемого параметром match. Поиск начинается с элемента, указываемого по индексу array[startIndex], и продолжается среди числа элементов, определяемых параметром count. Если ни один из элементов, удовлетворяющих данному условию, не найден, то возвращается значение -1 public static T FindLast<T>(T[] array, Predicate<T> match) Возвращает последний элемент массива array, удовлетворяющий условию предиката, задаваемого параметром match, иначе возвращает значение типа default(Т) public static int FindLastIndex<T>(Т[] array, Predicate<T> match) Возвращает индекс последнего элемента массива array, удовлетворяющего условию предиката, задаваемого параметром match, иначе возвращает значение -1 public static int FindLastIndex<T>(T[] array, int startIndex, Predicate<T> match) Возвращает индекс последнего элемента массива array, удовлетворяющего условию предиката, задаваемого параметром match. Поиск начинается в обратном порядке с элемента, указываемого по индексу array[startIndex], и оканчивается на элементе array[0]. Если ни один из элементов, удовлетворяющих данному условию, не найден, то возвращается значение -1 public static int FindLastIndex<T>(T[] array, int startIndex, int count, Predicate<T> match) Возвращает индекс последнего элемента массива array, удовлетворяющего условию предиката, задаваемого параметром v. Поиск начинается в обратном порядке с элемента, указываемого по индексу array[start], и продолжается среди числа элементов, определяемых параметром count. Если ни один из элементов, удовлетворяющих данному условию, не найден, то возвращается значение -1 public static void ForEach<T>(T[]array, Action<T> action) Применяет метод, задаваемый параметром action, к каждому элементу массива array public IEnumerator GetEnumerator Возвращает перечислительный объект для массива. Перечислители позволяют опрашивать массив в цикле. Боле подробно перечислители описываются в главе 25 public override int GetHashCode Возвращает хеш-код для вызывающего объекта public int GetLength(int dimension) Возвращает длину заданного измерения массива. Отсчет измерений начинается с нуля, поэтому для получения длины первого измерения необходимо передать данному методу значение 0 параметра dimension, для получения длины второго измерения — значение 1 и т.д. public long GetLongLength(int dimension) Возвращает длину заданного измерения массива в виде значения типа long. Отсчет измерений начинается с нуля, поэтому для получения длины первого измерения необходимо передать данному методу значение 0 параметра dimension, для получения длины второго измерения — значение 1 и т.д. public int GetLowerBound(int dimension) Возвращает начальный индекс заданного измерения массива, который обычно равен нулю. Параметр dimension определяет отсчет измерений с нуля, поэтому для получения начального индекса первого измерения необходимо передать данному методу значение 0 параметра dimension, для получения начального индекса второго измерения — значение 1 и т.д. public int GetUpperBound(int dimension) Возвращает конечный индекс заданного измерения массива. Параметр dimension определяет отсчет измерений с нуля, поэтому для получения конечного индекса первого измерения необходимо передать данному методу значение 0 параметра dimension, для получения конечного индекса второго измерения — значение 1 и т.д. public object GetValue(int index) Возвращает значение элемента из вызывающего массива по индексу index. Массив должен быть одномерным public object GetValue(long index) Возвращает значение элемента из вызывающего массива по индексу index. Массив должен быть одномерным public object GetValue(int index1, int index2) Возвращает значение элемента из вызывающего массива по индексам [index1, index2]. Массив должен быть двумерным public object GetValue(long index1, long index2) Возвращает значение элемента из вызывающего массива по индексам [index1, index2]. Массив должен быть двумерным public object GetValue(int index1, int index2, int index3) Возвращает значение элемента из вызывающего массива по индексам [index1, index2, index3]. Массив должен быть трехмерным public object GetValue(long index1, long index2, long idx3) Возвращает значение элемента из вызывающего массива по индексам [index1, index2, index3]. Массив должен быть трехмерным public object GetValue(int[] indices) Возвращает значение элемента из вызывающего массива по указанным индексам. Число измерений массива должно соответствовать числу элементов массива indices public object GetValue(long[] indices) Возвращает значение элемента из вызывающего массива по указанным индексам. Число измерений массива должно соответствовать числу элементов массива inices public static int IndexOf(Array array, object value) Возвращает индекс первого элемента, имеющего значение value в одномерном массиве array. Если искомое значение не найдено, то возвращает -1. (Если же массив имеет ненулевую нижнюю границу, то неудачный исход поиска будет обозначаться значением нижней границы, уменьшенным на 1.) public static int IndexOf<T>(T[] array, T value) Возвращает индекс первого элемента, имеющего значение value в одномерном массиве array. Если искомое значение не найдено, то возвращает -1 public static int IndexOf(Array array, object value, int startIndex) Возвращает индекс первого элемента, имеющего значение value в одномерном массиве array. Поиск начинается с элемента, указываемого по индексу array[startIndex]. Метод возвращает -1, если искомое значение не найдено. (Если массив имеет ненулевую нижнюю границу, то неудачный исход поиска будет обозначаться значением нижней границы, уменьшенным на 1.) public static int IndexOf<T>(T[] array, T value, int startIndex) Возвращает индекс первого элемента, имеющего значение value в одномерном массиве array. Поиск начинается с элемента, указываемого по индексу array[startIndex]. Метод возвращает -1, если искомое значение не найдено public static int IndexOf(Array array, object value, int startIndex, int count) Возвращает индекс первого элемента, имеющего значение value в одномерном массиве array. Поиск начинается с элемента, указываемого по индексу array[startIndex], и продолжается среди числа элементов, определяемых параметром count. Метод возвращает -1, если искомое значение не найдено в заданных пределах. (Если же массив имеет ненулевую нижнюю границу, то неудачный исход поиска будет обозначаться значением нижней границы, уменьшенным на 1.) public static int IndexOf<T>(T[] array, T value, int startIndex, int count) Возвращает индекс первого элемента, имеющего значение value в одномерном массиве array. Поиск начинается с элемента, указываемого по индексу array[startIndex], и продолжается среди числа элементов, определяемых параметром count. Метод возвращает -1, если искомое значение не найдено в заданных пределах public void Initialize Инициализирует каждый элемент вызывающего массива с помощью конструктора, используемого по умолчанию для соответствующего элемента. Этот метод можно использовать только для масси вов простых типов значений public static int LastlndexOf(Array array, object value) Возвращает индекс последнего элемента, имеющего значение value в одномерном массиве array. Если искомое значение не найдено, то возвращает -1. (Если массив имеет ненулевую нижнюю границу, то неудачный исход поиска будет обозначаться значением нижней границы, уменьшенным на 1.) public static int LastIndexOf<T>(T[] array, T value) Возвращает индекс последнего элемента, имеющего значение value в одномерном массиве array. Если искомое значение не найдено, то возвращает -1 public static int LastlndexOf(Array array, object value, int startIndex) Возвращает индекс последнего элемента, имеющего значение value в одномерном массиве array. Поиск начинается в обратном порядке с элемента, указываемого по индексу array[startIndex], и оканчивается на элементе а[0]. Метод возвращает -1, если искомое значение не найдено. (Если массив имеет ненулевую нижнюю границу, то неудачный исход поиска будет обозначаться значением нижней границы, уменьшенным на 1.) public static int LastIndexOf<T>(T[] array, T value, int startIndex) Возвращает индекс последнего элемента, имеющего значение value в одномерном массиве array. Поиск начинается в обратном порядке с элемента, указываемого по индексу а[startIndex], и оканчивается на элементе а[0]. Метод возвращает -1, если искомое значение не найдено public static int LastIndexOf(Array array, object value, int startIndex, int count) Возвращает индекс последнего элемента, имеющего значение value в одномерном массиве array. Поиск начинается в обратном порядке с элемента, указываемого по индексу array[startIndex], и продолжается среди числа элементов, определяемых параметром count. Метод возвращает -1, если искомое значение не найдено в заданных пределах. (Если массив имеет ненулевую нижнюю границу, то неудачный исход поиска будет обозначаться значением нижней границы, уменьшенным на 1.) public static int LastIndexOf<T>(T[]array, T value, int startIndex, int count) Возвращает индекс последнего элемента, имеющего значение value в одномерном массиве array. Поиск начинается в обратном порядке с элемента, указываемого по индексу array[startIndex], и продолжается среди числа элементов, определяемых параметром count. Метод возвращает -1, если искомое значение не найдено в заданных пределах public static void Resize<T>(ref T[] array, int newSize) Задает длину newSize массива array public static void Reverse(Array array) Меняет на обратный порядок следования элементов в массиве array public static void Reverse(Array array, int index, int length) Меняет на обратный порядок следования элементов массива array заданных в пределах, начиная с элемента, указываемого по индексу array[index], и включая число элементов, определяемых параметром length public void SetValue(object value, int index) Устанавливает значение value элемента вызывающего массива по индексу index. Массив должен быть одномерным public void SetValue(object value, long index) Устанавливает значение value элемента вызывающего массива по индексу index. Массив должен быть одномерным public void SetValue(object value, int index1, int index2) Устанавливает значение value элемента вызывающего массива по индексам [index1, index2]. Массив должен быть двумерным public void SetValue(object value, long index1, long index2) Устанавливает значение value элемента вызывающего массива по индексам [index1, index2]. Массив должен быть двумерным public void SetValue(object value, int index1, int index2, int index3) Устанавливает значение value элемента вызывающего массива по индексам [index1, index2, index3]. Массив должен быть трехмерным public void SetValue(object value, long index1, long index2, long index3) Устанавливает значение value элемента вызывающего массива по индексам [index1, index2, index3]. Массив должен быть трехмерным public void SetValue(object value, int[] indices) Устанавливает значение value элемента вызывающего массива по указанным индексам. Число измерений массива должно соответствовать числу элементов массива indices public void SetValue(object value, long[]indices) Устанавливает значение value элемента вызывающего массива по указанным индексам. Число измерений массива должно соответствовать числу элементов массива indices public static void Sort(Array array) Сортирует массив array по нарастающей. Массив должен быть одномерным public static void Sort<T>(T[]array) Сортирует массив array по нарастающей. Массив должен быть одномерным public static void Sort(Array array, IComparer comparer) Сортирует массив array по нарастающей, используя способ сравнения, задаваемый параметром comparer. Массив должен быть одномерным public static void Sort<T> (T[] array, Comparison<T> comparer) Сортирует массив array по нарастающей, используя способ сравнения, задаваемый параметром comparer. Массив должен быть одномерным public static void Sort<T> (T[] array, IComparer<T> comparer) Сортирует массив array по нарастающей, используя способ сравнения, задаваемый параметром comparer. Массив должен быть одномерным public static void Sort(Array keys, Array items) Сортирует по нарастающей два заданных одномерных массива. Массив keys содержит ключи сортировки, а массив items — значения, связанные с этими ключами. Следовательно, оба массива должны содержать пары “ключ-значение”. После сортировки элементы обоих массивов располагаются по порядку нарастания ключей public static void Sort<TKey, TValue>(TKey[] keys, TV[] items) Сортирует по нарастающей два заданных одномерных массива. Массив keys содержит ключи сортировки, а массив items — значения, связанные с этими ключами. Следовательно, оба массива должны содержать пары “ключ-значение”. После сортировки элементы обоих массивов располагаются по порядку возрастания ключей public static void Sort(Array keys, Array items, Icomparer comparer) Сортирует по нарастающей два заданных одномерных массива, используя способ сравнения, задаваемый параметром comparer. Массив keys содержит ключи сортировки, а массив items — значения, связанные с этими ключами. Следовательно, оба массива должны содержать пары “ключ-значение”. После сортировки элементы обоих массивов располагаются по порядку возрастания ключей public static void Sort<TKey, TValue>(TKey[] keys, TValue[] items, IComparer<TKey> comparer) Сортирует по нарастающей два заданных одномерных массива, используя способ сравнения, задаваемый параметром comparer. Массив keys содержит ключи сортировки, а массив items — значения, связанные с этими ключами. Следовательно, оба массива должны содержать пары “ключ-значение”. После сортировки элементы обоих массивов располагаются по порядку возрастания ключей public static void Sort(Array array, int index, int length) Сортирует массив array по нарастающей в заданных пределах, начиная с элемента, указываемого по индексу array[index], и включая число элементов, определяемых параметром length. Массив должен быть одномерным public static void Sort<T>(T[] array, int index, int length) Сортирует массив array по нарастающей в заданных пределах, начиная с элемента, указываемого по индексу array[index], и включая число элементов, определяемых параметром length. Массив должен быть одномерным public static void Sort(Array array, int index, int length, IComparer comparer) Сортирует массив array по нарастающей в заданных пределах, начиная с элемента, указываемого по индексу array[index], и включая число элементов, определяемых параметром length, а также используя способ сравнения, задаваемый параметром v. Массив должен быть одномерным public static void Sort<T>(T[] array, int index, int length, Icomparer<T> comparer) Сортирует массив array по нарастающей в заданных пределах, начиная с элемента, указываемого по индексу array[index], и включая число элементов, определяемых параметром length, а также используя способ сравнения, задаваемый параметром comparer. Массив должен быть одномерным public static void Sort(Array keys, Array Items, int index, int length) Сортирует по нарастающей два одномерных массива в заданных пределах, начиная с элемента, указываемого по индексу index, и включая число элементов, определяемых параметром length. Массив keys содержит ключи сортировки, а массив items — значения, связанные с этими ключами. Следовательно, оба массива должны содержать пары “ключ-значение”. После сортировки элементы обоих массивов располагаются в заданных пределах по порядку возрастания ключей public static void Sort<TKey, TValue>(TKey[] keys, TValue[] items, int index, int length) Сортирует по нарастающей два одномерных массива в заданных пределах, начиная с элемента, указываемого по индексу index, и включая число элементов, определяемых параметром length. Массив keys содержит ключи сортировки, а массив items — значения, связанные с этими ключами. Следовательно, оба массива должны содержать пары “ключ-значение”. После сортировки элементы обоих массивов располагаются в заданных пределах по порядку возрастания ключей public static void Sort(Array keys, Array items, int index, int length, IComparer comparer) Сортирует по нарастающей два одномерных массива в заданных пределах, начиная с элемента, указываемого по индексу index, и включая число элементов, определяемых параметром length, а также используя способ сравнения, задаваемый параметром comparer. Массив keys содержит ключи сортировки, а массив items — значения, связанные с этими ключами. Следовательно, эти два массива должны содержать пары “ключ-значение". После сортировки элементы обоих массивов располагаются в заданных пределах по порядку возрастания ключей public static void Sort<TKey, TValue>(TKey[] keys, TV items, int index, int length, Icomparer<TKey> comparer) Сортирует по нарастающей два одномерных массива в заданных пределах, начиная с элемента, указываемого по индексу index, и включая число элементов, определяемых параметром length, а также используя способ сравнения, задаваемый параметром comparer. Массив keys содержит ключи сортировки, а массив items — значения, связанные с этими ключами. Следовательно, эти два массива должны содержать пары.“ключ-значение”. После сортировки элементы обоих массивов располагаются в заданных пределах по порядку возрастания ключей public static bool TrueForAll<T>(Т[] array, Predicate<T> match) Возвращает логическое значение true, если все элементы массива array удовлетворяют условию предиката, задаваемого параметром match. Если один или более элементов этого массива не удовлетворяют заданному условию, то возвращается логическое значение false Сортировка и поиск в массивах