Добавить в цитаты Настройки чтения

Страница 42 из 188

Отдельный символ выбирается из строки с помощью индекса, как в приведенномниже фрагменте кода.string str = "тест";Console.WriteLine(str[0]);

В этом фрагменте кода выводится символ "т", который является первым в строке"тест". Как и в массивах, индексирование строк начинается с нуля. Следует, однако,иметь в виду, что с помощью индекса нельзя присвоить новое значение символу в строке. Индекс может служить только для выборки символа из строки.

Для проверки двух строк на равенство служит оператор ==. Как правило, если оператор == применяется к ссылкам на объект, то он определяет, являются ли они ссылками на один и тот же объект. Совсем иначе обстоит дело с объектами типа string.Когда оператор == применяется к ссылкам на две строки, он сравнивает содержимоеэтих строк. Это же относится и к оператору !=. В обоих случаях выполняется порядковое сравнение. Для проверки двух строк на равенство с учетом культурной средыслужит метод Equals(), где непременно нужно указать способ сравнения в виде аргумента StringComparison.CurrentCulture. Следует также иметь в виду, что метод Compare() служит для сравнения строк с целью определить отношение порядка,например для сортировки. Если же требуется проверить символьные строки на равенство, то для этой цели лучше воспользоваться методом Equals() или строковымиоператорами.

В приведенном ниже примере программы демонстрируется несколько операцийсо строками.// Некоторые операции со строками.using System;using System.Globalization;class StrOps { static void Main() { string str1 = "Программировать в .NET лучше всего на С#."; string str2 = "Программировать в .NET лучше всего на С#."; string str3 = "Строки в C# весьма эффективны."; string strUp, strLow; int result, idx; Console.WriteLine("str1: " + str1); Console.WriteLine("Длина строки str1: " + str1.Length); // Создать варианты строки str1, набранные // прописными и строчными буквами. strLow = str1.ToLower(CultureInfo.CurrentCulture); strUp = str1.ToUpper(CultureInfo.CurrentCulture); Console.WriteLine("Вариант строки str1, " + "набранный строчными буквами:n " + strLow); Console.WriteLine("Вариант строки str1, " + "набранный прописными буквами:n " + strUp); Console.WriteLine(); // Вывести строку str1 посимвольно. Console.WriteLine("Вывод строки str1 посимвольно."); for (int i=0; i < str1.Length; i++) Console.Write(str1[i]); Console.WriteLine("n"); // Сравнить строки способом порядкового сравнения. if(str1 == str2) Console.WriteLine("str1 == str2"); else Console.WriteLine("str1 != str2"); if(str1 == str3) Console.WriteLine("str1 == str3"); else Console.WriteLine("str1 != str3"); // Сравнить строки с учетом культурной среды. result = string.Compare(str3, str1, StringComparison.CurrentCulture); if(result == 0) Console.WriteLine("Строки str1 и str3 равны"); else if (result < 0) Console.WriteLine("Строка str1 меньше строки str3"); else Console.WriteLine("Строка str1 больше строки str3"); Console.WriteLine(); // Присвоить новую строку переменной str2. str2 = "Один Два Три Один"; // Поиск подстроки. idx = str2.IndexOf("Один", StringComparison.Ordinal); Console.WriteLine("Индекс первого вхождения подстроки <Один>: " + idx); idx = str2.LastIndexOf("Один", StringComparison.Ordinal); Console.WriteLine("Индекс последнего вхождения подстроки <Один>: " + idx); }}

При выполнении этой программы получается следующий результат.str1: Программировать в .NET лучше всего на С#.Длина строки str1: 41Вариант строки str1, набранный строчными буквами:программировать в .net лучше всего на c#.Вариант строки str1, набранный прописными буквами:программировать в .net лучше всего на c#.Вывод строки str1 посимвольно.Программировать в .NET лучше всего на С#.str1 == str2str1 != str3Строка str1 больше строки str3Индекс первого вхождения подстроки <Один>: 0Индекс последнего вхождения подстроки <Один>: 13

Прежде чем читать дальше, обратите внимание на то, что метод Compare() вызывается следующим образом.result = string.Compare(str1, str3, StringComparison.CurrentCulture);

Как пояснялось ранее, метод Compare() объявляется как static, и поэтому он вызывается по имени, а не по экземпляру своего класса.

С помощью оператора + можно сцепить (т.е. объединить вместе) две строки.Например, в следующем фрагменте кода:string str1 = "Один";string str2 = "Два";string str3 = "Три";string str4 = str1 + str2 + str3;

переменная str4 инициализируется строкой "ОдинДваТри".



И еще одно замечание: ключевое слово string является псевдонимом классаSystem.String, определенного в библиотеке классов для среды .NET Framework,т.е. оно устанавливает прямое соответствие с этим классом. Следовательно, поляи методы, определяемые типом string, относятся непосредственно к классуSystem.String, в который входят и многие другие компоненты. Подробнее о классеSystem.String речь пойдет в части II этой книги.Массивы строк

Аналогично данным любого другого типа, строки могут быть организованы в массивы. Ниже приведен соответствующий пример.// Продемонстрировать массивы строк.using System;class StringArrays { static void Main() { string[] str = { "Это", "очень", "простой", "тест." }; Console.WriteLine("Исходный массив: "); for(int i=0; i < str.Length; i++) Console.Write(str[i] + " "); Console.WriteLine("n"); // Изменить строку. str[l] = "тоже"; str[3] = "до предела тест!"; Console.WriteLine("Видоизмененный массив: "); for(int i=0; i < str.Length; i++) Console.Write(str[i] + " "); }}

Вот какой результат дает выполнение приведенного выше кода.Исходный массив:Это очень простой тест.Видоизмененный массив:Это тоже простой до предела тест!

Рассмотрим более интересный пример. В приведенной ниже программе целое число выводится словами. Например, число 19 выводится словами "один девять".// Вывести отдельные цифры целого числа словами.using System;class ConvertDigitsToWords { static void Main() { int num; int nextdigit; int numdigits; int[] n = new int[20]; string[] digits = { "нуль", "один", "два", "три", "четыре", "пять", "шесть", "семь", "восемь", "девять" }; num = 1908; Console.WriteLine("Число: " + num); Console.Write("Число словами: "); nextdigit = 0; numdigits = 0; // Получить отдельные цифры и сохранить их в массиве n. // Эти цифры сохраняются в обратном порядке. do { nextdigit = num % 10; n[numdigits] = nextdigit; numdigits++; num = num / 10; } while(num > 0); numdigits--; // Вывести полученные слова. for( ; numdigits >= 0; numdigits--) Console.Write(digits[n[numdigits]] + " "); Console.WriteLine(); }}

Выполнение этой программы приводит к следующему результату.Число: 1908Число словами: один девять нуль восемь

В данной программе использован массив строк digits для хранения словесныхобозначений цифр от 0 до 9. По ходу выполнения программы целое число преобразуется в слова. Для этого сначала получаются отдельные цифры числа, а затем они сохраняются в обратном порядке следования в массиве n типа int. После этого выполняетсяциклический опрос массива n в обратном порядке. При этом каждое целое значениеиз массива п служит в качестве индекса, указывающего на слова, соответствующие полученным цифрам числа и выводимые как строки.Постоянство строк

Как ни странно, содержимое объекта типа string не подлежит изменению. Этоозначает, что однажды созданную последовательность символов изменить нельзя. Ноданное ограничение способствует более эффективной реализации символьных строк.Поэтому этот, на первый взгляд, очевидный недостаток на самом деле превращается впреимущество. Так, если требуется строка в качестве разновидности уже имеющейсястроки, то для этой цели следует создать новую строку, содержащую все необходимыеизменения. А поскольку неиспользуемые строковые объекты автоматически собираются в "мусор", то о дальнейшей судьбе ненужных строк можно даже не беспокоиться.