Что такое findslide.org?

FindSlide.org - это сайт презентаций, докладов, шаблонов в формате PowerPoint.


Для правообладателей

Обратная связь

Email: Нажмите что бы посмотреть 

Яндекс.Метрика

Презентация на тему Поворение материала 1 семестра. Основы языка С#. Основы ООП. Типы и структуры данных

Содержание

©Павловская Т.А. (НИУ ИТМО)Основы языка С#
©Павловская Т.А. (НИУ ИТМО)Повторение материала I семестра Основы языка С# Основы ООП Типы и структуры данных ©Павловская Т.А. (НИУ ИТМО)Основы языка С# ©Павловская Т.А. (НИУ ИТМО)Состав языкаСимволы:буквы: 		 A-Z, a-z, _, буквы нац. алфавитовцифры: ©Павловская Т.А. (НИУ ИТМО)  Вид				ПримерыБулевские		true	false				Целые  десятич.	8	 199226 	0Lu			  16-ричн.	0xA	0x1B8		0X00FFL	Веществ. ©Павловская Т.А. (НИУ ИТМО)внутреннее представление данных  => множество их возможных значенийдопустимые ©Павловская Т.А. (НИУ ИТМО)Основная классификация типов C# ©Павловская Т.А. (НИУ ИТМО)Хранение в памяти величин значимого и ссылочного типа ©Павловская Т.А. (НИУ ИТМО)Логический (булевский) и целые ©Павловская Т.А. (НИУ ИТМО)Остальные ©Павловская Т.А. (НИУ ИТМО)using System;namespace A{    class Class1 ©Павловская Т.А. (НИУ ИТМО)Переменные Переменная — это величина, которая во время работы ©Павловская Т.А. (НИУ ИТМО)Общая структура программы на С#пространство именКласс АКласс ВМетод MainПеременные ©Павловская Т.А. (НИУ ИТМО)Область действия и время жизни переменныхПеременные описываются внутри какого-л. ©Павловская Т.А. (НИУ ИТМО)Инициализация переменных При объявлении можно присвоить переменной начальное значение ©Павловская Т.А. (НИУ ИТМО)Тип результата выраженияЕсли входящие в выражение операнды одного типа ©Павловская Т.А. (НИУ ИТМО)Явное преобразование типаАвтоматическое (неявное) преобразование возможно не всегда, а ©Павловская Т.А. (НИУ ИТМО)Неявные арифметические преобразования типов в C#при отсутствии линии возникает ошибка компиляции ©Павловская Т.А. (НИУ ИТМО)using System;namespace A{  class Class1  { ©Павловская Т.А. (НИУ ИТМО)using System;namespace A{  class Class1  { ©Павловская Т.А. (НИУ ИТМО)using System;namespace A{  class Class1  { ©Павловская Т.А. (НИУ ИТМО)using System;namespace A{  class Class1  { ©Павловская Т.А. (НИУ ИТМО)using System;namespace CA1{  class Class1  { ©Павловская Т.А. (НИУ ИТМО)Управляющие операторы языка высокого уровня: следование ветвление цикл передача управленияРеализуют логику выполнения программы ©Павловская Т.А. (НИУ ИТМО)Блок (составной оператор)Блок — последовательность операторов, заключенная в операторные ©Павловская Т.А. (НИУ ИТМО)Условный оператор ifif ( a < 0 ) b ©Павловская Т.А. (НИУ ИТМО)Оператор выбора switchswitch ( выражение ){	case константное_выражение_1: [ список_операторов_1 ©Павловская Т.А. (НИУ ИТМО)Пример: Калькулятор на четыре действия using System; namespace ConsoleApplication1{ ©Павловская Т.А. (НИУ ИТМО)Операторы цикла: с предусловием - while с постусловием - ©Павловская Т.А. (НИУ ИТМО)Цикл с предусловием while ( выражение ) операторusing System;namespace ©Павловская Т.А. (НИУ ИТМО)Цикл с постусловием do   операторwhile выражение;using System;namespace ©Павловская Т.А. (НИУ ИТМО)using System;namespace ConsoleApplication1{  class Class1  { ©Павловская Т.А. (НИУ ИТМО)Передача управленияоператор break — завершает выполнение цикла, внутри которого ©Павловская Т.А. (НИУ ИТМО)using System;namespace ConsoleApplication1{  class Class1  { Простая проверка ввода©Павловская Т.А. (НИУ ИТМО)// пример проверки формата вводимого значения:double a;if Проверка ввода с помощью цикла do-whileusing System;namespace ConsoleApplication1{  class Program Рекомендуемая структура обработки ошибок исходных данных©Павловская Т.А. (НИУ ИТМО)ошибка 1?ввод данныхсообщение 1ошибка ©Павловская Т.А. (НИУ ИТМО)Понятие «исключительная ситуация» При вычислении выражений могут возникнуть ошибки ©Павловская Т.А. (НИУ ИТМО)Механизм обработки исключенийФункция или операция, в которой возникла ошибка, ©Павловская Т.А. (НИУ ИТМО)Пример 1: try {		// Контролируемый блок }catch ( OverflowException ©Павловская Т.А. (НИУ ИТМО)Пример 2: проверка ввода static void Main() { ©Павловская Т.А. (НИУ ИТМО)Рекомендации по программированию – 1/2 Главная цель, к которой ©Павловская Т.А. (НИУ ИТМО)Рекомендации по программированию – 2/2 В программе необходимо предусматривать ©Павловская Т.А. (НИУ ИТМО)Основы ООП ©Павловская Т.А. (СПбГУ ИТМО)Достоинства ООП использование при программировании понятий, близких к предметной ©Павловская Т.А. (СПбГУ ИТМО)Недостатки ООП идеи ООП не просты для понимания и ©Павловская Т.А. (СПбГУ ИТМО)Абстрагирование и инкапсуляцияПри представлении реального объекта с помощью программного ©Павловская Т.А. (СПбГУ ИТМО)НаследованиеНаследование (inheritance) - это процесс, посредством которого один объект ©Павловская Т.А. (СПбГУ ИТМО)ПолиморфизмООП позволяет писать гибкие, расширяемые и читабельные программы. Во ©Павловская Т.А. (СПбГУ ИТМО)Понятие классаКласс является типом данных, определяемым пользователем. Он должен ©Павловская Т.А. (СПбГУ ИТМО)Описание класса [ атрибуты ] [ спецификаторы ] class ©Павловская Т.А. (СПбГУ ИТМО)Элементы класса ©Павловская Т.А. (СПбГУ ИТМО)Описание объекта (экземпляра)Класс является обобщенным понятием, определяющим характеристики и ©Павловская Т.А. (СПбГУ ИТМО)Данные: поля и константы Данные, содержащиеся в классе, могут ©Павловская Т.А. (СПбГУ ИТМО)Методы Метод — функциональный элемент класса, реализующий вычисления или Синтаксис метода[ атрибуты ] [ спецификаторы ] тип имя_метода ( [ параметры ©Павловская Т.А. (СПбГУ ИТМО)Параметры методовПараметры определяют множество значений аргументов, которые можно передавать ©Павловская Т.А. (СПбГУ ИТМО)Вызов метода Вычисляются выражения, стоящие на месте аргументов.Выделяется память Способы передачи аргументов в методПри передаче по значению метод получает копии значений ©Павловская Т.А. (СПбГУ ИТМО)Типы параметровВ С# четыре типа параметров: параметры-значения - для Передача аргумента по значениюкод методаобласть параметроваргументкопияаргументаПри вызове метода на месте параметра, передаваемого Передача аргумента по ссылке (ref, out)код методаобласть параметроваргументадресаргументаПри вызове метода на месте ©Павловская Т.А. (СПбГУ ИТМО)Пример: параметры-значения и ссылки refusing System;namespace ConsoleApplication1{  class ©Павловская Т.А. (СПбГУ ИТМО)Пример: выходные параметры outusing System;namespace ConsoleApplication1{  class Class1 ©Павловская Т.А. (СПбГУ ИТМО)Summary: Правила применения параметровДля параметров-значений используется передача по значению. ©Павловская Т.А. (СПбГУ ИТМО)Ключевое слово this Чтобы обеспечить работу метода с полями ©Павловская Т.А. (СПбГУ ИТМО)Использование явного thisВ явном виде параметр this применяется: 1) КонструкторыКонструктор – особый вид метода, предназначенный для инициализации объекта (конструктор экземпляра) или ©Павловская Т.А. (СПбГУ ИТМО)Конструкторы экземпляраКонструктор вызывается автоматически при создании объекта класса с ©Павловская Т.А. (СПбГУ ИТМО)Сквозной пример классаclass Monster {  public Monster() ©Павловская Т.А. (СПбГУ ИТМО)СвойстваСвойства служат для организации доступа к полям класса. Как Пример: счетчик (свойства) class Counter{   public Counter() { } ©Павловская Т.А. (СПбГУ ИТМО)Сквозной пример класса: свойстваclass Monster {  public Monster() ©Павловская Т.А. (СПбГУ ИТМО)Перегрузка методов Использование нескольких методов с одним и тем ©Павловская Т.А. (СПбГУ ИТМО)Операции класса В С# можно переопределить для своих классов Пример: счетчик (операция ++) class Counter{   public Counter() { Пример: счетчик (операция +) class Counter{   ... ©Павловская Т.А. (НИУ ИТМО)Проектирование классаSummary ©Павловская Т.А. (СПбГУ ИТМО)Интерфейс класса При создании класса следует хорошо продумать его ©Павловская Т.А. (СПбГУ ИТМО)Состав классаКак правило, класс как тип, определенный пользователем, должен ©Павловская Т.А. (СПбГУ ИТМО)Элементы классаМетоды определяют поведение класса. Каждый метод класса должен ©Павловская Т.А. (НИУ ИТМО)Типы и структуры данных Перечислимый тип данныхПеречисление — отдельный тип-значение, содержащий совокупность именованных констант. Пример: enum Color ©Павловская Т.А. (НИУ ИТМО) Массив — ограниченная совокупность однотипных величин Элементы массива имеют ©Павловская Т.А. (НИУ ИТМО)Создание массиваМассив относится к ссылочным типам данных (располагается в ©Павловская Т.А. (НИУ ИТМО)Одномерные массивы Варианты описания массива:тип[] имя;тип[] имя = new ©Павловская Т.А. (НИУ ИТМО)Оператор foreach (упрощенно)Применяется для перебора элементов массива. Синтаксис:foreach ( ©Павловская Т.А. (НИУ ИТМО)Программа в true style ☺class Mas_1 public int NumOtr() class Program Пример анализа заданияНайти среднее арифметическое элементов, расположенных между минимумом и максимумомВарианты результата:выводится ©Павловская Т.А. (НИУ ИТМО)Использование методов класса Array static void Main() Что вы должны уметь найти в массиве:минимум/максимум [по модулю]номер минимума/максимума [по модулю]номер ©Павловская Т.А. (НИУ ИТМО)Прямоугольные массивы Прямоугольный массив имеет более одного измерения. Чаще ©Павловская Т.А. (НИУ ИТМО)ПримерПрограмма определяет: среднее арифметическое всех элементов;количество положительных элементов в ©Павловская Т.А. (НИУ ИТМО)const int m = 3, n = 4;int[,] a ©Павловская Т.А. (НИУ ИТМО)int nPosEl;for ( int i = 0; i < ©Павловская Т.А. (СПбГУ ИТМО)Строки типа string Тип string предназначен для работы со ©Павловская Т.А. (СПбГУ ИТМО)Операции для строкприсваивание (=);проверка на равенство (==);проверка на неравенство ©Павловская Т.А. (СПбГУ ИТМО)Пример: разбиение текста на словаStreamReader inputFile = new StreamReader( ©Павловская Т.А. (СПбГУ ИТМО)Регулярные выраженияРегулярное выражение — шаблон (образец), по которому выполняется поиск ©Павловская Т.А. (СПбГУ ИТМО)Язык описания регулярных выраженийЯзык описания регулярных выражений состоит из ©Павловская Т.А. (СПбГУ ИТМО)Метасимволы - классы символов ©Павловская Т.А. (СПбГУ ИТМО)продолжение таблицы ©Павловская Т.А. (СПбГУ ИТМО)Повторители ©Павловская Т.А. (СПбГУ ИТМО)Примеры простых регулярных выражений целое число (возможно, со знаком): Поддержка регулярных выражений в .NETДля поддержки регулярных выражений в библиотеку .NET включены Методы класса Regex позволяют выполнять следующие действия: Определить, встречается ли во входном using System; using System.Text.RegularExpressions; public class Example { public static void Main() ©Павловская Т.А. (СПбГУ ИТМО)Абстрактные структуры данных Массив  конечная совокупность однотипных величин. ©Павловская Т.А. (СПбГУ ИТМО)Контейнеры http://msdn.microsoft.com/ru-ru/library/ybcx56wz.aspx?ppud=4Контейнер (коллекция) - стандартный класс, реализующий абстрактную структуру ©Павловская Т.А. (СПбГУ ИТМО)Параметризованные коллекции (классы-прототипы, generics) - классы, имеющие типы данных в качестве параметров Повторение: контейнеры и файлы©Павловская Т.А. (СПбГУ ИТМО)QueueStackLinkedListArrayListStringCollectionListHashTableSortedListDictionaryStringDictionary ©Павловская Т.А. (СПбГУ ИТМО)Пример использования класса Listusing System;using System.Collections.Generic;namespace ConsoleApplication1{class Program { ©Павловская Т.А. (СПбГУ ИТМО)Общие принципы работы с файлами Чтение (ввод)  — передача ©Павловская Т.А. (СПбГУ ИТМО)Уровни обмена с внешними устройствамиВыполнять обмен с внешними устройствами ©Павловская Т.А. (СПбГУ ИТМО)Доступ к файламДоступ к файлам может быть:последовательным - очередной ©Павловская Т.А. (СПбГУ ИТМО)Пример чтения из текстового файла  static void Main() ©Павловская Т.А. (СПбГУ ИТМО)Построчное чтение текстового файла 		   StreamReader f ©Павловская Т.А. (СПбГУ ИТМО)Чтение чисел из текстового файла – вар. 1try { ©Павловская Т.А. (СПбГУ ИТМО)Чтение чисел из текстового файла – вар. 2try { Организация справки MSDNДля каждого элемента:ИмяНазначениеПространство имен, сборкаСинтаксис (Syntax)Описание (Remarks)Примеры (Examples)Иерархия наследования, платформы,
Слайды презентации

Слайд 2 ©Павловская Т.А. (НИУ ИТМО)
Основы языка С#

©Павловская Т.А. (НИУ ИТМО)Основы языка С#

Слайд 3 ©Павловская Т.А. (НИУ ИТМО)
Состав языка
Символы:
буквы: A-Z, a-z,

©Павловская Т.А. (НИУ ИТМО)Состав языкаСимволы:буквы: 		 A-Z, a-z, _, буквы нац.

_, буквы нац. алфавитов
цифры: 0-9, A-F
спец. символы: +,

*, {, …
пробельные символы

Лексемы:
константы 2 0.11 “Вася”
имена Vasia a _11
ключевые слова double do if
знаки операций + <= new
разделители ; [ ] ,

Выражения
выражение - правило вычисления значения: a + b
Операторы
исполняемые: c = a + b;
описания: double a, b;

static void Main()
{ Самолёт АН24 =
new Самолёт();
АН24.Полетели();
}

Лексема (token, токен) – минимальная единица языка, имеющая самостоятельный смысл



Слайд 4 ©Павловская Т.А. (НИУ ИТМО)
Вид Примеры
Булевские true false
Целые десятич. 8

©Павловская Т.А. (НИУ ИТМО) Вид				ПримерыБулевские		true	false				Целые десятич.	8	 199226 	0Lu			 16-ричн.	0xA	0x1B8		0X00FFL	Веществ. с тчк	5.7

199226 0Lu
16-ричн. 0xA 0x1B8 0X00FFL
Веществ. с тчк 5.7 .001f 35m
с

порядком 0.2E6 .11e–3 5E12
Символьные 'A' '\x74' '\0' '\\' '\uA81B' Строковые "Здесь был Vasia"
"\tЗначение r=\xF5\n"
"Здесь был \u0056\u0061"
@"C:\temp\file1.txt"
Константа null null

Константы (литералы) C#

Кодировка Unicode

Суффикс
типа

Управляющий символ

5∙1012


Слайд 5 ©Павловская Т.А. (НИУ ИТМО)
внутреннее представление данных =>

©Павловская Т.А. (НИУ ИТМО)внутреннее представление данных => множество их возможных значенийдопустимые

множество их возможных значений

допустимые действия над данными => операции

и функции

Тип данных определяет:

Концепция типа данных


Слайд 6 ©Павловская Т.А. (НИУ ИТМО)
Основная классификация типов C#

©Павловская Т.А. (НИУ ИТМО)Основная классификация типов C#

Слайд 7 ©Павловская Т.А. (НИУ ИТМО)
Хранение в памяти величин значимого

©Павловская Т.А. (НИУ ИТМО)Хранение в памяти величин значимого и ссылочного типа

и ссылочного типа


Слайд 8 ©Павловская Т.А. (НИУ ИТМО)
Логический (булевский) и целые

©Павловская Т.А. (НИУ ИТМО)Логический (булевский) и целые

Слайд 9 ©Павловская Т.А. (НИУ ИТМО)
Остальные

©Павловская Т.А. (НИУ ИТМО)Остальные

Слайд 10 ©Павловская Т.А. (НИУ ИТМО)
using System;
namespace A
{

©Павловская Т.А. (НИУ ИТМО)using System;namespace A{  class Class1  {

class Class1
{

static void Main()
{
// описания и операторы, например:
Console.Write("Превед медвед");
}

// описания
}
}

Структура простейшей программы на С#


Слайд 11 ©Павловская Т.А. (НИУ ИТМО)
Переменные
Переменная — это

©Павловская Т.А. (НИУ ИТМО)Переменные Переменная — это величина, которая во время

величина, которая во время работы программы может изменять свое

значение.
Все переменные, используемые в программе, должны быть описаны.
Для каждой переменной задается ее имя и тип:
int number; float x, y; char option;

Тип переменной выбирается исходя из диапазона и требуемой точности представления данных.

Слайд 12 ©Павловская Т.А. (НИУ ИТМО)
Общая структура программы на С#

пространство

©Павловская Т.А. (НИУ ИТМО)Общая структура программы на С#пространство именКласс АКласс ВМетод

имен

Класс А

Класс В

Метод Main
Переменные класса
Методы класса:


Переменные класса
Локальные переменные
Методы

класса:




Слайд 13 ©Павловская Т.А. (НИУ ИТМО)
Область действия и время жизни

©Павловская Т.А. (НИУ ИТМО)Область действия и время жизни переменныхПеременные описываются внутри

переменных
Переменные описываются внутри какого-л. блока:
1) класса


2) метода или блока внутри метода
Переменные, описанные непосредственно внутри класса, называются полями класса.
Переменные, описанные внутри метода класса, называются локальными переменными.
Область действия переменной - область программы, где можно использовать переменную.
Область действия переменной начинается в точке ее описания и длится до конца блока, внутри которого она описана.
Время жизни: переменные создаются при входе в их область действия (блок) и уничтожаются при выходе.

Блок — код, заключенный в фигурные скобки. Основное назначение блока — группировка операторов.


Слайд 14 ©Павловская Т.А. (НИУ ИТМО)
Инициализация переменных
При объявлении можно

©Павловская Т.А. (НИУ ИТМО)Инициализация переменных При объявлении можно присвоить переменной начальное

присвоить переменной начальное значение (инициализировать).
int number = 100; float x

= 0.02; char option = ’ю’;
При инициализации можно использовать не только константы, но и выражения — главное, чтобы на момент описания они были вычислимыми, например:
int b = 1, a = 100;
int x = b * a + 25;
Поля класса инициализируются «значением по умолчанию» (0 соответствующего типа).
Локальные переменные автоматически НЕ инициализируются. Рекомендуется всегда явным образом инициализировать переменные при описании.

Слайд 15 ©Павловская Т.А. (НИУ ИТМО)
Тип результата выражения
Если входящие в

©Павловская Т.А. (НИУ ИТМО)Тип результата выраженияЕсли входящие в выражение операнды одного

выражение операнды одного типа и операция для этого типа

определена, то результат выражения будет иметь тот же тип.
Если операнды разного типа и (или) операция для этого типа не определена, перед вычислениями автоматически выполняется преобразование типа по правилам, обеспечивающим приведение более коротких типов к более длинным для сохранения значимости и точности.
char c = 'A';
int i = 100;
double d = 1;
double summa = c + i + d; // 166


Слайд 16 ©Павловская Т.А. (НИУ ИТМО)
Явное преобразование типа
Автоматическое (неявное) преобразование

©Павловская Т.А. (НИУ ИТМО)Явное преобразование типаАвтоматическое (неявное) преобразование возможно не всегда,

возможно не всегда, а только если при этом не

может случиться потеря значимости.
Если неявного преобразования из одного типа в другой не существует, программист может задать явное преобразование типа с помощью операции (тип) x.
char c = 'A';
int i = 100;
double d = 1;
с = (char) i; // 'd'
c = (char) d;
i = (int) d;


Слайд 17 ©Павловская Т.А. (НИУ ИТМО)
Неявные арифметические преобразования типов в

©Павловская Т.А. (НИУ ИТМО)Неявные арифметические преобразования типов в C#при отсутствии линии возникает ошибка компиляции

C#
при отсутствии линии возникает ошибка компиляции


Слайд 18 ©Павловская Т.А. (НИУ ИТМО)
using System;
namespace A
{ class

©Павловская Т.А. (НИУ ИТМО)using System;namespace A{ class Class1 { static void

Class1
{ static void Main()

{
int i = 3;
double y = 4.12;
decimal d = 600m;
string s = "Вася";





}
}
}

Вывод на консоль – 1/4

Результат работы программы:
3 y = 4,12
d = 600 s = Вася

Console.Write( i );
Console.WriteLine( " y = " + y);
Console.WriteLine("d = " + d + " s = " + s );


Слайд 19 ©Павловская Т.А. (НИУ ИТМО)
using System;
namespace A
{ class

©Павловская Т.А. (НИУ ИТМО)using System;namespace A{ class Class1 { static void

Class1
{ static void Main()

{
int i = 3;
double y = 4.12;
decimal d = 600m;
string s = "Вася";




}
}
}

Вывод на консоль – 2/4

Результат работы программы:
3 y = 4,12
d = 600 s = Вася

Console.Write( i );
Console.Write( " y = {0} \nd = {1}", y, d );
Console.WriteLine( " s = " + s );




Слайд 20 ©Павловская Т.А. (НИУ ИТМО)
using System;
namespace A
{ class

©Павловская Т.А. (НИУ ИТМО)using System;namespace A{ class Class1 { static void

Class1
{ static void Main()

{
int i = 3;
double y = 4.12;
decimal d = 600m;
string s = "Вася";




}
}
}

Вывод на консоль – 3/4

Результат работы программы:
3 y = 4,12
d = 600 s = Вася

Console.Write( i );
Console.Write( " y = {0:F2} \nd = {1:D3}", y, d );
Console.WriteLine( " s = " + s );

Формат

Формат


Слайд 21 ©Павловская Т.А. (НИУ ИТМО)
using System;
namespace A
{ class

©Павловская Т.А. (НИУ ИТМО)using System;namespace A{ class Class1 { static void

Class1
{ static void Main()

{
string s = Console.ReadLine(); // ввод строки

char c = (char)Console.Read(); // ввод символа
Console.ReadLine();

int i = Convert.ToInt32( Console.ReadLine() );

double x = Convert.ToDouble( Console.ReadLine() );

double y = double.Parse( Console.ReadLine() );
}
}
}

Ввод с консоли – 2/2


Слайд 22 ©Павловская Т.А. (НИУ ИТМО)
using System;
namespace CA1
{ class

©Павловская Т.А. (НИУ ИТМО)using System;namespace CA1{ class Class1 { static void

Class1
{ static void Main()

{
Console.WriteLine( "Введите температуру по Фаренгейту" );
double fahr = Convert.ToDouble( Console.ReadLine() );

double cels =5.0 / 9 * (fahr - 32);

Console.WriteLine( "По Фаренгейту: {0} в градусах Цельсия: {1}",
fahr, cels );
}
}
}

Пример: перевод температуры из F в С



Слайд 23
©Павловская Т.А. (НИУ ИТМО)
Управляющие операторы языка высокого уровня:

©Павловская Т.А. (НИУ ИТМО)Управляющие операторы языка высокого уровня: следование ветвление цикл передача управленияРеализуют логику выполнения программы

следование
ветвление
цикл
передача управления

Реализуют логику выполнения программы


Слайд 24 ©Павловская Т.А. (НИУ ИТМО)
Блок (составной оператор)
Блок — последовательность

©Павловская Т.А. (НИУ ИТМО)Блок (составной оператор)Блок — последовательность операторов, заключенная в

операторов, заключенная в операторные скобки:
begin end

– в Паскале
{ } - в С-подобных языках
Блок воспринимается компилятором как один оператор и может использоваться всюду, где синтаксис требует одного оператора, а алгоритм — нескольких.
Блок может содержать один оператор или быть пустым.

Слайд 25 ©Павловская Т.А. (НИУ ИТМО)
Условный оператор if
if ( a

©Павловская Т.А. (НИУ ИТМО)Условный оператор ifif ( a < 0 )

< 0 ) b = 1;
if ( a

b && (a > d || a == 0) ) ++b;
else { b *= a; a = 0; }
if ( a < b ) if ( a < c ) m = a; else m = c; else if ( b < c ) m = b; else m = c;

if ( выражение ) оператор_1; [else оператор_2;]

Простой или {блок}


Слайд 26 ©Павловская Т.А. (НИУ ИТМО)
Оператор выбора switch
switch ( выражение

©Павловская Т.А. (НИУ ИТМО)Оператор выбора switchswitch ( выражение ){	case константное_выражение_1: [

){
case константное_выражение_1: [ список_операторов_1 ]
case константное_выражение_2: [ список_операторов_2 ]

case

константное_выражение_n: [ список_операторов_n ]
[ default: операторы ]
}

Слайд 27 ©Павловская Т.А. (НИУ ИТМО)
Пример: Калькулятор на четыре действия

©Павловская Т.А. (НИУ ИТМО)Пример: Калькулятор на четыре действия using System; namespace


using System; namespace ConsoleApplication1
{ class Class1 {

static void Main() {
Console.WriteLine( "Введите 1й операнд:" );
double a = double.Parse(Console.ReadLine());
Console.WriteLine( "Введите знак" );
char op = (char)Console.Read(); Console.ReadLine();
Console.WriteLine( "Введите 2й операнд:" );
double b = double.Parse(Console.ReadLine());
double res = 0;
bool ok = true;
switch (op)
{ case '+' : res = a + b; break;
case '-' : res = a - b; break;
case '*' : res = a * b; break;
case '/' : res = a / b; break;
default : ok = false; break;
}
if (ok) Console.WriteLine( "Результат: " + res );
else Console.WriteLine( "Недопустимая операция" );
}}}

Слайд 28 ©Павловская Т.А. (НИУ ИТМО)
Операторы цикла:
с предусловием -

©Павловская Т.А. (НИУ ИТМО)Операторы цикла: с предусловием - while с постусловием

while
с постусловием - do
с параметром -

for
перебора - foreach

Слайд 29 ©Павловская Т.А. (НИУ ИТМО)
Цикл с предусловием
while (

©Павловская Т.А. (НИУ ИТМО)Цикл с предусловием while ( выражение ) операторusing

выражение ) оператор
using System;
namespace ConsoleApplication1
{ class Class1

{ static void Main()
{
double Xn = -2, Xk = 12, dX = 2, t = 2, y;
Console.WriteLine( "| x | y |" );

double x = Xn;
while ( x <= Xk )
{
y = t * x;
Console.WriteLine( "| {0,9} | {1,9} |", x, y );
x += dX;
}
}
}
}

y = t⋅x


Слайд 30 ©Павловская Т.А. (НИУ ИТМО)
Цикл с постусловием
do

©Павловская Т.А. (НИУ ИТМО)Цикл с постусловием do  операторwhile выражение;using System;namespace

оператор
while выражение;


using System;
namespace ConsoleApplication1
{ class Program

{ static void Main()
{
char answer;
do
{
Console.WriteLine( "Купи слоника, а?" );
answer = (char) Console.Read();
Console.ReadLine();
} while ( answer != 'y' );
}
}
}

Удобно использовать
для проверки ввода


Слайд 31 ©Павловская Т.А. (НИУ ИТМО)
using System;
namespace ConsoleApplication1
{ class

©Павловская Т.А. (НИУ ИТМО)using System;namespace ConsoleApplication1{ class Class1 { static void

Class1
{ static void Main()

{
double Xn = -2, Xk = 12, dX = 2, t = 2, y;
Console.WriteLine( "| x | y |";
for ( double x = Xn; x <= Xk; x += dX )
{
y = t * x;
Console.WriteLine( "| {0,9} | {1,9} |", x, y );
}
}
}
}

Пример цикла с параметром


Слайд 32 ©Павловская Т.А. (НИУ ИТМО)
Передача управления
оператор break — завершает

©Павловская Т.А. (НИУ ИТМО)Передача управленияоператор break — завершает выполнение цикла, внутри

выполнение цикла, внутри которого записан
оператор continue — выполняет переход

к следующей итерации цикла
оператор return — выполняет выход из функции, внутри которой он записан
оператор goto — выполняет безусловную передачу управления
оператор throw — генерирует исключительную ситуацию.

Слайд 33 ©Павловская Т.А. (НИУ ИТМО)
using System;
namespace ConsoleApplication1
{ class

Class1
{ static void Main()

{ double e = 1e-6; const int iterLimit = 500;
Console.WriteLine( "Введите аргумент:" );
double x = Convert.ToDouble(Console.ReadLine());

Пример: вычисление суммы ряда

bool error = false; // признак ошибки
double c = x, y = c; // член ряда и сумма ряда
for ( int n = 1; Math.Abs(c) > e; n++ )
{ c *= - x * x / ((2 * n ) * ( 2 * n + 1 ));
y += c;
if ( n > iterLimit ) { error = true; break; }
}
if ( error ) Console.WriteLine( "Ряд расходится" );
else Console.WriteLine( "Сумма ряда - " + y );
}}} end.





Слайд 34 Простая проверка ввода
©Павловская Т.А. (НИУ ИТМО)
// пример проверки

Простая проверка ввода©Павловская Т.А. (НИУ ИТМО)// пример проверки формата вводимого значения:double

формата вводимого значения:

double a;
if (! double.TryParse(Console.ReadLine(), out a) )


{Console.WriteLine(" Неверный формат "); return; }

// при вводе более одного значения предпочтительнее
// использовать механизм исключений


// пример проверки допустимости значения:

double a = double.Parse(Console.ReadLine());
...
if ( a <= 0 )
{ Console.WriteLine("Неверное значение (<= 0)" );
return;
}

не гуманно!

не человеколюбиво!


Слайд 35 Проверка ввода с помощью цикла do-while
using System;
namespace ConsoleApplication1
{

class Program
{ static void Main()

{
const int max_attempts = 3;
int i = 0;
do
{
Console.WriteLine( "Введите значение > 0:" );
double a = double.Parse(Console.ReadLine());
++i; if ( i >= max_attempts ) { … return; }
} while ( a <= 0 );
}
} // ограничивать кол-во попыток обязательно!
}

©Павловская Т.А. (НИУ ИТМО)


Слайд 36 Рекомендуемая структура обработки ошибок исходных данных
©Павловская Т.А. (НИУ

Рекомендуемая структура обработки ошибок исходных данных©Павловская Т.А. (НИУ ИТМО)ошибка 1?ввод данныхсообщение

ИТМО)
ошибка 1?
ввод данных
сообщение 1
ошибка 2?
сообщение 2
основной поток
вычислений
выход
выход
...
НЕ в толще

вложенных блоков!

да

да


Слайд 37 ©Павловская Т.А. (НИУ ИТМО)
Понятие «исключительная ситуация»
При вычислении

©Павловская Т.А. (НИУ ИТМО)Понятие «исключительная ситуация» При вычислении выражений могут возникнуть

выражений могут возникнуть ошибки (переполнение, деление на ноль).
В

C# есть механизм обработки исключительных ситуаций (исключений), который позволяет избегать аварийного завершения программы.
Если в процессе вычислений возникла ошибка, система сигнализирует об этом с помощью выбрасывания (генерирования) исключения.
Каждому типу ошибки соответствует свое исключение. Исключения являются классами, которые имеют общего предка — класс Exception, определенный в пространстве имен System.
Например, при делении на ноль будет выброшено исключение DivideByZeroException, при переполнении — исключение OverflowException.
В программе необходимо предусмотреть обработку исключений.

Слайд 38 ©Павловская Т.А. (НИУ ИТМО)
Механизм обработки исключений
Функция или операция,

©Павловская Т.А. (НИУ ИТМО)Механизм обработки исключенийФункция или операция, в которой возникла

в которой возникла ошибка, генерируют исключение;
Выполнение текущего блока прекращается,

отыскивается соответствующий обработчик исключения, ему передается управление.
В любом случае (была ошибка или нет) выполняется блок finally, если он присутствует.
Если обработчик не найден, вызывается стандартный обработчик исключения.

Слайд 39 ©Павловская Т.А. (НИУ ИТМО)
Пример 1:
try {

// Контролируемый

©Павловская Т.А. (НИУ ИТМО)Пример 1: try {		// Контролируемый блок }catch (

блок
}
catch ( OverflowException e ) {

// Обработка

переполнения
}
catch ( DivideByZeroException ) {

// Обработка деления на 0
}
catch {
// Обработка всех остальных исключений
}

Слайд 40 ©Павловская Т.А. (НИУ ИТМО)
Пример 2: проверка ввода
static

©Павловская Т.А. (НИУ ИТМО)Пример 2: проверка ввода static void Main() {

void Main() {
try

{
Console.WriteLine( "Введите напряжение:" );
double u = double.Parse( Console.ReadLine() );
Console.WriteLine( "Введите сопротивление:" );
double r = double.Parse(Console.ReadLine() );
double i = u / r;
Console.WriteLine( "Сила тока - " + i );
}
catch ( FormatException )
{
Console.WriteLine( "Неверный формат ввода!" );
}
catch // общий случай
{
Console.WriteLine( "Неопознанное исключение" );
}
}

if (u < 0)
{ Console.WriteLine( "Недопустимое …" );
return; }




Слайд 41 ©Павловская Т.А. (НИУ ИТМО)
Рекомендации по программированию – 1/2

©Павловская Т.А. (НИУ ИТМО)Рекомендации по программированию – 1/2 Главная цель, к


Главная цель, к которой нужно стремиться, — получить легко читаемую

программу возможно более простой структуры.
Создание программы начинают с определения ее исходных данных и результатов (тип, диапазон).
Затем записывают на естественном языке (возможно, с применением обобщенных блок-схем), что именно и как должна делать программа.
При кодировании необходимо помнить о принципах структурного программирования: программа должна состоять из четкой последовательности блоков — базовых конструкций.
Имена переменных должны отражать их смысл. Переменные желательно инициализировать при их объявлении.
Следует избегать использования в программе чисел в явном виде (кроме 0 и 1).
Программа должна быть «прозрачна». Для записи каждого фрагмента алгоритма используются наиболее подходящие средства языка.

Слайд 42 ©Павловская Т.А. (НИУ ИТМО)
Рекомендации по программированию – 2/2

©Павловская Т.А. (НИУ ИТМО)Рекомендации по программированию – 2/2 В программе необходимо


В программе необходимо предусматривать реакцию на неверные входные данные.


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

Слайд 43 ©Павловская Т.А. (НИУ ИТМО)
Основы ООП

©Павловская Т.А. (НИУ ИТМО)Основы ООП

Слайд 44 ©Павловская Т.А. (СПбГУ ИТМО)
Достоинства ООП
использование при программировании

©Павловская Т.А. (СПбГУ ИТМО)Достоинства ООП использование при программировании понятий, близких к

понятий, близких к предметной области;
возможность успешно управлять большими объемами

исходного кода благодаря инкапсуляции, то есть скрытию деталей реализации объектов и упрощению структуры программы;
возможность многократного использования кода за счет наследования;
сравнительно простая возможность модификации программ;
возможность создания и использования библиотек объектов.

Слайд 45 ©Павловская Т.А. (СПбГУ ИТМО)
Недостатки ООП
идеи ООП не

©Павловская Т.А. (СПбГУ ИТМО)Недостатки ООП идеи ООП не просты для понимания

просты для понимания и в особенности для практического использования
для

эффективного использования существующих объектно-ориентированных систем и библиотек требуется большой объем первоначальных знаний
неграмотное применение ООП может привести к значительному ухудшению характеристик разрабатываемой программы
некоторое снижение быстродействия программы, связанное с использованием виртуальных методов


Слайд 46 ©Павловская Т.А. (СПбГУ ИТМО)
Абстрагирование и инкапсуляция
При представлении реального

©Павловская Т.А. (СПбГУ ИТМО)Абстрагирование и инкапсуляцияПри представлении реального объекта с помощью

объекта с помощью программного необходимо выделить в первом его

существенные особенности и игнорировать несущественные. Это называется абстрагированием.
Таким образом, программный объект — это абстракция.
Детали реализации объекта скрыты, он используется через его интерфейс — совокупность правил доступа.
Скрытие деталей реализации называется инкапсуляцией. Это позволяет представить программу в укрупненном виде — на уровне объектов и их взаимосвязей, а следовательно, управлять большим объемом информации.
Итак, объект — это инкапсулированная абстракция с четко определенным интерфейсом.

Слайд 47 ©Павловская Т.А. (СПбГУ ИТМО)
Наследование
Наследование (inheritance) - это процесс,

©Павловская Т.А. (СПбГУ ИТМО)НаследованиеНаследование (inheritance) - это процесс, посредством которого один

посредством которого один объект может приобретать свойства другого.
Важное

значение имеет возможность многократного использования кода. Для объекта можно определить наследников, корректирующих или дополняющих его поведение.
Наследование применяется для:
исключения из программы повторяющихся фрагментов кода;
упрощения модификации программы;
упрощения создания новых программ на основе существующих.
Благодаря наследованию появляется возможность использовать объекты, исходный код которых недоступен, но в которые требуется внести изменения.
Наследование позволяет создавать иерархии объектов. Иерархия представляется в виде дерева, в котором более общие объекты располагаются ближе к корню, а более специализированные — на ветвях и листьях.

Слайд 48 ©Павловская Т.А. (СПбГУ ИТМО)
Полиморфизм
ООП позволяет писать гибкие, расширяемые

©Павловская Т.А. (СПбГУ ИТМО)ПолиморфизмООП позволяет писать гибкие, расширяемые и читабельные программы.

и читабельные программы.
Во многом это обеспечивается благодаря полиморфизму,

под которым понимается возможность во время выполнения программы с помощью одного и того же имени выполнять разные действия или обращаться к объектам разного типа.
Чаще всего понятие полиморфизма связывают с механизмом виртуальных методов.

Слайд 49 ©Павловская Т.А. (СПбГУ ИТМО)
Понятие класса
Класс является типом данных,

©Павловская Т.А. (СПбГУ ИТМО)Понятие классаКласс является типом данных, определяемым пользователем. Он

определяемым пользователем. Он должен представлять собой одну логическую сущность,

например, являться моделью реального объекта или процесса. Элементами класса являются данные и функции, предназначенные для их обработки (методы).
Все классы .NET имеют общего предка — класс object, и организованы в единую иерархическую структуру.
Классы логически сгруппированы в пространства имен, которые служат для упорядочивания имен классов и предотвращения конфликтов имен: в разных пространствах имена могут совпадать. Пространства имен могут быть вложенными.
Любая программа использует пространство имен System.

Слайд 50 ©Павловская Т.А. (СПбГУ ИТМО)
Описание класса
[ атрибуты ]

©Павловская Т.А. (СПбГУ ИТМО)Описание класса [ атрибуты ] [ спецификаторы ]

[ спецификаторы ] class имя_класса [ : предки ]

тело_класса
Имя класса задается по общим правилам.
Тело класса — список описаний его элементов, заключенный в фигурные скобки.
Атрибуты задают дополнительную информацию о классе.
Спецификаторы определяют свойства класса, а также доступность класса для других элементов программы.
Простейшие примеры описания класса:
class Demo {} // пустой класс
public class Двигатель // класс с одним методом
{ public void Запуск()
{ Console.WriteLine( " пыщь пыщь " ); }
}


Слайд 51 ©Павловская Т.А. (СПбГУ ИТМО)
Элементы класса

©Павловская Т.А. (СПбГУ ИТМО)Элементы класса

Слайд 52 ©Павловская Т.А. (СПбГУ ИТМО)
Описание объекта (экземпляра)
Класс является обобщенным

©Павловская Т.А. (СПбГУ ИТМО)Описание объекта (экземпляра)Класс является обобщенным понятием, определяющим характеристики

понятием, определяющим характеристики и поведение множества конкретных объектов этого

класса, называемых экземплярами (объектами) класса.
Объекты создаются явным или неявным образом (либо программистом, либо системой). Программист создает экземпляр класса с помощью операции new:
Demo a = new Demo();
Monster Vasia = new Monster();
Monster Petya = new Monster(“Петя“);
Для каждого объекта при его создании в памяти выделяется отдельная область для хранения его данных.
Кроме того, в классе могут присутствовать статические элементы, которые существуют в единственном экземпляре для всех объектов класса.
Функциональные элементы класса всегда хранятся в единственном экземпляре.

Слайд 53 ©Павловская Т.А. (СПбГУ ИТМО)
Данные: поля и константы
Данные,

©Павловская Т.А. (СПбГУ ИТМО)Данные: поля и константы Данные, содержащиеся в классе,

содержащиеся в классе, могут быть переменными или константами.
Переменные,

описанные в классе, называются полями класса.
При описании полей можно указывать атрибуты и спецификаторы, задающие различные характеристики элементов:
[ атрибуты ] [ спецификаторы ] [ const ] тип имя [ = начальное_значение ]
public int a = 1;
public static string s = "Demo";
double y;
Все поля сначала автоматически инициализируются нулем соответствующего типа (например, полям типа int присваивается 0, а ссылкам на объекты — значение null). После этого полю присваивается значение, заданное при его явной инициализации.

Слайд 54 ©Павловская Т.А. (СПбГУ ИТМО)
Методы
Метод — функциональный элемент

©Павловская Т.А. (СПбГУ ИТМО)Методы Метод — функциональный элемент класса, реализующий вычисления

класса, реализующий вычисления или другие действия. Методы определяют поведение

класса и составляют его интерфейс.
Метод — законченный фрагмент кода, к которому можно обратиться по имени. Он описывается один раз, а вызываться может столько раз, сколько необходимо.
Один и тот же метод может обрабатывать различные данные, переданные ему в качестве аргументов.

double a = 0.1;
double b = Math.Sin(a);
double c = Math.Sin(b-2*a);

Console.WriteLine(a);


Слайд 55 Синтаксис метода
[ атрибуты ] [ спецификаторы ] тип

Синтаксис метода[ атрибуты ] [ спецификаторы ] тип имя_метода ( [

имя_метода ( [ параметры ] ) тело_метода

Спецификаторы: new, public,

protected, internal, protected internal, private, static, virtual, sealed, override, abstract, extern.
Метод класса имеет непосредственный доступ к его полям.
Пример:

class Demo {
double y; // закрытое поле класса

public void Sety( double z ) { // открытый метод класса
y = z;
}
}

… Demo demo = new Demo(); // где-то в методе другого класса
demo.Sety(3.12); … // вызов метода



Слайд 56 ©Павловская Т.А. (СПбГУ ИТМО)
Параметры методов
Параметры определяют множество значений

©Павловская Т.А. (СПбГУ ИТМО)Параметры методовПараметры определяют множество значений аргументов, которые можно

аргументов, которые можно передавать в метод.
Список аргументов при

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

Слайд 57 ©Павловская Т.А. (СПбГУ ИТМО)
Вызов метода
Вычисляются выражения, стоящие

©Павловская Т.А. (СПбГУ ИТМО)Вызов метода Вычисляются выражения, стоящие на месте аргументов.Выделяется

на месте аргументов.
Выделяется память под параметры метода.
Каждому из параметров

сопоставляется соответствующий аргумент. При этом проверяется соответствие типов аргументов и параметров и при необходимости выполняется их преобразование. При несоответствии типов выдается диагностическое сообщение.
Выполняется тело метода.
Если метод возвращает значение, оно передается в точку вызова; если метод имеет тип void, управление передается на оператор, следующий после вызова.

Слайд 58 Способы передачи аргументов в метод
При передаче по значению

Способы передачи аргументов в методПри передаче по значению метод получает копии

метод получает копии значений аргументов, и операторы метода работают

с этими копиями.
При передаче по ссылке (по адресу) метод получает копии адресов аргументов и осуществляет доступ к аргументам по этим адресам.

Аргументы передаются:

По значению
По адресу (ссылке)


Слайд 59 ©Павловская Т.А. (СПбГУ ИТМО)
Типы параметров
В С# четыре типа

©Павловская Т.А. (СПбГУ ИТМО)Типы параметровВ С# четыре типа параметров: параметры-значения -

параметров:
параметры-значения - для исходных данных метода;
параметры-ссылки (ref) -

для изменения аргумента;
выходные параметры (out) – для формирования аргумента;
параметры-массивы (params) – для переменного кол-ва аргументов.


параметр-значение


параметр-ссылка


выходной параметр


параметр-массив

Пример:
public int Calculate( int a, ref int b, out int c, params int[] d ) { …


по адресу


Слайд 60 Передача аргумента по значению
код метода
область параметров
аргумент
копия
аргумента
При вызове метода

Передача аргумента по значениюкод методаобласть параметроваргументкопияаргументаПри вызове метода на месте параметра,

на месте параметра, передаваемого по значению, может находиться выражение

(а также его частные случаи — переменная или константа).
Должно существовать неявное преобразование типа выражения к типу параметра.


double a = 0.1;
double b = Math.Sin(a);
double c = Math.Sin(b-2*a);

static int Max(int a, int b) { … }

int x = Max(3, z);


Слайд 61 Передача аргумента по ссылке (ref, out)
код метода
область параметров
аргумент
адрес
аргумента
При

Передача аргумента по ссылке (ref, out)код методаобласть параметроваргументадресаргументаПри вызове метода на

вызове метода на месте параметра-ссылки ref может находиться только

имя инициализированной переменной точно того же типа. Перед именем параметра указывается ключевое слово ref.
При вызове метода на месте выходного параметра out может находиться только имя переменной точно того же типа. Ее инициализация не требуется. Перед именем параметра указывается ключевое слово out.



int SomeMethod(ref int a, out int b) { … }

int s = 0; int z;
int x = SomeMethod(ref s, out z);


Слайд 62 ©Павловская Т.А. (СПбГУ ИТМО)
Пример: параметры-значения и ссылки ref
using

©Павловская Т.А. (СПбГУ ИТМО)Пример: параметры-значения и ссылки refusing System;namespace ConsoleApplication1{ class

System;
namespace ConsoleApplication1
{ class Class1
{ static

void P( int a, ref int b )
{
a = 44; b = 33;
Console.WriteLine( "внутри метода {0} {1}", a, b );
}
static void Main()
{
int a = 2, b = 4;
Console.WriteLine( "до вызова {0} {1}", a, b );
P( a, ref b );
Console.WriteLine( "после вызова {0} {1}", a, b );
}}}

Результат работы программы:
до вызова 2 4
внутри метода 44 33
после вызова 2 33


Слайд 63 ©Павловская Т.А. (СПбГУ ИТМО)
Пример: выходные параметры out
using System;
namespace

©Павловская Т.А. (СПбГУ ИТМО)Пример: выходные параметры outusing System;namespace ConsoleApplication1{ class Class1

ConsoleApplication1
{ class Class1
{ static void

P( int x, out int y )
{
x = 44; y = 33;
Console.WriteLine( "внутри метода {0} {1}", x, y );
}
static void Main()
{
int a = 2, b; // инициализация b не требуется

P( a, out b );
Console.WriteLine( "после вызова {0} {1}", a, b );
}}}

Результат работы программы:

внутри метода 44 33
после вызова 2 33


Слайд 64 ©Павловская Т.А. (СПбГУ ИТМО)
Summary: Правила применения параметров
Для параметров-значений

©Павловская Т.А. (СПбГУ ИТМО)Summary: Правила применения параметровДля параметров-значений используется передача по

используется передача по значению. Этот способ применяется для исходных

данных метода.
При вызове метода на месте параметра, передаваемого по значению, может находиться выражение (а также его частные случаи — переменная или константа). Должно существовать неявное преобразование типа выражения к типу параметра.
Параметры-ссылки и выходные параметры передаются по адресу. Этот способ применяется для передачи побочных результатов метода.
При вызове метода на месте параметра-ссылки ref может находиться только имя инициализированной переменной точно того же типа. Перед именем параметра указывается ключевое слово ref.
При вызове метода на месте выходного параметра out может находиться только имя переменной точно того же типа. Ее инициализация не требуется. Перед именем параметра указывается ключевое слово out.

Слайд 65 ©Павловская Т.А. (СПбГУ ИТМО)
Ключевое слово this
Чтобы обеспечить

©Павловская Т.А. (СПбГУ ИТМО)Ключевое слово this Чтобы обеспечить работу метода с

работу метода с полями того объекта, для которого он

был вызван, в метод автоматически передается скрытый параметр this, в котором хранится ссылка на вызвавший функцию объект.


Метод Main:
Monster a = new…
Monster b = new…
a.Passport()
b.Passport()

Метод Passport:
Вывод полей
name
health
ammo

ДАННЫЕ (хип):

Объект a:
name
health
ammo

Объект b:
name
health
ammo

this=a

this=b

this.name
this.health this.ammo

КОД:


Слайд 66 ©Павловская Т.А. (СПбГУ ИТМО)
Использование явного this
В явном виде

©Павловская Т.А. (СПбГУ ИТМО)Использование явного thisВ явном виде параметр this применяется:

параметр this применяется:

1) чтобы возвратить из метода ссылку

на вызвавший объект:
class Demo
{ double y;
public Demo T() { return this; }

// 2) для идентификации поля, если его имя совпадает с
// именем параметра метода:

public void Sety( double y ) { this.y = y; }
}


Слайд 67 Конструкторы
Конструктор – особый вид метода, предназначенный для инициализации

КонструкторыКонструктор – особый вид метода, предназначенный для инициализации объекта (конструктор экземпляра)

объекта (конструктор экземпляра) или класса (статический конструктор).
Конструктор экземпляра инициализирует

данные экземпляра, конструктор класса — данные класса.

©Павловская Т.А. (СПбГУ ИТМО)


Слайд 68 ©Павловская Т.А. (СПбГУ ИТМО)
Конструкторы экземпляра
Конструктор вызывается автоматически при

©Павловская Т.А. (СПбГУ ИТМО)Конструкторы экземпляраКонструктор вызывается автоматически при создании объекта класса

создании объекта класса с помощью операции new. Имя конструктора

совпадает с именем класса.
Свойства конструкторов:
Конструктор не возвращает значение, даже типа void.
Класс может иметь несколько конструкторов с разными параметрами для разных видов инициализации.
Если программист не указал ни одного конструктора или какие-то поля не были инициализированы, полям значимых типов присваивается нуль, полям ссылочных типов — значение null.
Конструктор, вызываемый без параметров, называется конструктором по умолчанию.

Слайд 69 ©Павловская Т.А. (СПбГУ ИТМО)
Сквозной пример класса
class Monster {

public Monster() // конструктор
{

name = "Noname";
health = 100;
ammo = 100;
}
public Monster( string name ) : this()
{
this.name = name;
}
public Monster( int health, int ammo, string name )
{
this.name = name;
this.health = health > 0 ? health : 0 ;
this.ammo = ammo > 0 ? ammo : 0 ;
}
public string GetName() // метод
{ return name; }
public int GetAmmo() // метод
{ return ammo;}

public int Health { // свойство
get { return health; }
set { if (value > 0) health = value;
else health = 0;
}
}

public void Passport() // метод
{ Console.WriteLine(
"Monster {0} \t health = {1} \
ammo = {2}", name, health, ammo );
}

public override string ToString(){
string buf = string.Format(
"Monster {0} \t health = {1} \
ammo = {2}", name, health, ammo);
return buf; }

string name;
int health, ammo;
}

Monster Vasia = new Monster();
Monster Petya = new Monster(“Петя“);
Monster Masha = new Monster(150, 3000, “Мария”);


Слайд 70 ©Павловская Т.А. (СПбГУ ИТМО)
Свойства
Свойства служат для организации доступа

©Павловская Т.А. (СПбГУ ИТМО)СвойстваСвойства служат для организации доступа к полям класса.

к полям класса. Как правило, свойство определяет методы доступа

к закрытому полю.
Свойства обеспечивают разделение между внутренним состоянием объекта и его интерфейсом.
Синтаксис свойства:
[ спецификаторы ] тип имя_свойства
{
[ get код_доступа ]
[ set код_доступа ]
}
При обращении к свойству автоматически вызываются указанные в нем блоки чтения (get) и установки (set).
Может отсутствовать либо часть get, либо set, но не обе одновременно. Если отсутствует часть set, свойство доступно только для чтения (read-only), если отсутствует get - только для записи (write-only).

Слайд 71 Пример: счетчик (свойства)
class Counter
{ public

Пример: счетчик (свойства) class Counter{  public Counter() { }

Counter() { }
public Counter( int

n ) { this.n = n > 0 ? n : 0; }
public int N
{ get { return n; }
set { n = value > 0 ? value : 0; }
}
// или: set { if (value > 0) n = value; else throw new Exception();}
int n; // поле, связанное со свойством N
}
class Program
{ static void Main(string[] args)
{ Counter num = new Counter();
num.N = 5; // работает set
int a = num.N; // работает get
num.N++; // работает get, а потом set
++num.N; // работает get, а потом set
}}

©Павловская Т.А. (СПбГУ ИТМО)


Слайд 72 ©Павловская Т.А. (СПбГУ ИТМО)
Сквозной пример класса: свойства
class Monster

{
public Monster() // конструктор

{
this.name = "Noname";
this.health = 100;
this.ammo = 100;
}
public Monster( string name ) : this()
{
this.name = name;
}
public Monster( int health, int ammo, string name )
{
this.name = name;
this.health = health;
this.ammo = ammo;
}
public string GetName() // метод
{ return name; }
public int GetAmmo() // метод
{ return ammo;}

public int Health { // свойство
get { return health; }
set {health = value > 0 ? value : 0;
}
}
public string Name { // свойство
get { return name; }
}
public void Passport() // метод
{ Console.WriteLine(
"Monster {0} \t health = {1} \
ammo = {2}", name, health, ammo );
}
public override string ToString(){
string buf = string.Format(
"Monster {0} \t health = {1} \
ammo = {2}", name, health, ammo);
return buf; }

string name;
int health, ammo;
}


Слайд 73 ©Павловская Т.А. (СПбГУ ИТМО)
Перегрузка методов
Использование нескольких методов

©Павловская Т.А. (СПбГУ ИТМО)Перегрузка методов Использование нескольких методов с одним и

с одним и тем же именем, но различными типами

параметров называется перегрузкой методов.
Компилятор определяет, какой именно метод требуется вызвать, по типу фактических параметров. Это называется разрешением (resolution) перегрузки.
// Возвращает наибольшее из двух целых:
int max( int a, int b )
// Возвращает наибольшее из трех целых:
int max( int a, int b, int c )
// Возвращает наибольшее из первого параметра
// и длины второго:
int max ( int a, string b )
...
Console.WriteLine( max( 1, 2 ) );
Console.WriteLine( max( 1, 2, 3 ) );
Console.WriteLine( max( 1, "2" ) );
Перегрузка методов является проявлением полиморфизма

Слайд 74 ©Павловская Т.А. (СПбГУ ИТМО)
Операции класса
В С# можно

©Павловская Т.А. (СПбГУ ИТМО)Операции класса В С# можно переопределить для своих

переопределить для своих классов действие большинства операций. Это позволяет

применять экземпляры объектов в составе выражений аналогично переменным стандартных типов:
MyObject a, b, c; ...
c = a + b; // операция сложения класса MyObject
Определение собственных операций класса называют перегрузкой операций.
Операции класса описываются с помощью методов специального вида (функций-операций):
public static имя_класса operator операция( параметры) {… }

Пример: public static MyObject operator --( MyObject m ) { … }

В C# три вида операций класса: унарные, бинарные и операции преобразования типа.

Слайд 75 Пример: счетчик (операция ++)
class Counter
{

Пример: счетчик (операция ++) class Counter{  public Counter() {

public Counter() { }
public Counter(

int n ) { this.n = n > 0 ? n : 0; }
public static Counter operator ++(Counter param)
{
Counter temp = new Counter(param.n + 1);
return temp;
}
int n;
}
class Program
{ static void Main(string[] args)
{ Counter num = new Counter();
num++; ++num;
...
}
}

©Павловская Т.А. (СПбГУ ИТМО)


Слайд 76 Пример: счетчик (операция +)
class Counter
{

Пример: счетчик (операция +) class Counter{  ...

...
public static Counter operator

+(Counter param, int delta)
{ Counter temp = new Counter(param.n + delta);
return temp;
}
public static Counter operator +(int delta, Counter param)
{ Counter temp = new Counter(param.n + delta);
return temp;
}
int n;
}
class Program
{ static void Main(string[] args)
{ Counter num = new Counter(); Counter num2 = new Counter();
num2 = num + 3; num2 = 3 + num;
...
}
}

©Павловская Т.А. (СПбГУ ИТМО)


Слайд 77 ©Павловская Т.А. (НИУ ИТМО)
Проектирование класса
Summary

©Павловская Т.А. (НИУ ИТМО)Проектирование классаSummary

Слайд 78 ©Павловская Т.А. (СПбГУ ИТМО)
Интерфейс класса
При создании класса

©Павловская Т.А. (СПбГУ ИТМО)Интерфейс класса При создании класса следует хорошо продумать

следует хорошо продумать его интерфейс — средства работы с классом,

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

Слайд 79 ©Павловская Т.А. (СПбГУ ИТМО)
Состав класса
Как правило, класс как

©Павловская Т.А. (СПбГУ ИТМО)Состав классаКак правило, класс как тип, определенный пользователем,

тип, определенный пользователем, должен содержать скрытые (private) поля и

следующие функциональные элементы:
конструкторы, определяющие, как инициализируются объекты класса;
набор методов и свойств, реализующих характеристики класса;
классы исключений, используемые для сообщений об ошибках путем генерации исключительных ситуаций.
Классы, моделирующие математические или физические понятия, обычно также содержат набор операций, позволяющих копировать, присваивать, сравнивать объекты и производить с ними другие действия, требующиеся по сути класса.



Слайд 80 ©Павловская Т.А. (СПбГУ ИТМО)
Элементы класса
Методы определяют поведение класса.

©Павловская Т.А. (СПбГУ ИТМО)Элементы классаМетоды определяют поведение класса. Каждый метод класса

Каждый метод класса должен решать только одну задачу.
Создание любого

метода следует начинать с его интерфейса (заголовка). Необходимо четко представлять себе, какие параметры метод должен получать и какие результаты формировать. Входные параметры обычно перечисляют в начале списка параметров.
Поля, характеризующие класс в целом, следует описывать как статические.
Все литералы, связанные с классом, описываются как поля-константы с именами, отражающими их смысл.
Необходимо стремиться к максимальному сокращению области действия каждой переменной. Это упрощает отладку программы, поскольку ограничивает область поиска ошибки.


Слайд 81 ©Павловская Т.А. (НИУ ИТМО)
Типы и структуры данных

©Павловская Т.А. (НИУ ИТМО)Типы и структуры данных

Слайд 82 Перечислимый тип данных
Перечисление — отдельный тип-значение, содержащий совокупность

Перечислимый тип данныхПеречисление — отдельный тип-значение, содержащий совокупность именованных констант. Пример: enum

именованных констант.
Пример:
 
enum Color : long
{
Red,

Green,
Blue
}
Каждый элемент перечисления имеет связанное с ним константное значение, тип которого определяется базовым типом перечисления.
Базовые типы: byte, sbyte, short, ushort, int, uint, long и ulong. По умолчанию – int.

©Павловская Т.А. (НИУ ИТМО)

Базовый класс - System.Enum.
Перечисление может иметь модификатор (new, public, protected, internal, private). Он имеет такое же значение, как и при объявлении классов.


Слайд 83 ©Павловская Т.А. (НИУ ИТМО)

Массив — ограниченная совокупность однотипных

©Павловская Т.А. (НИУ ИТМО) Массив — ограниченная совокупность однотипных величин Элементы массива

величин
Элементы массива имеют одно и то же имя,

а различаются по порядковому номеру (индексу)
Виды массивов в C#:
одномерные
многомерные (например, двумерные, или прямоугольные)
массивы массивов (др. термины: невыровненные, ступенчатые).

Массивы


Слайд 84 ©Павловская Т.А. (НИУ ИТМО)
Создание массива
Массив относится к ссылочным

©Павловская Т.А. (НИУ ИТМО)Создание массиваМассив относится к ссылочным типам данных (располагается

типам данных (располагается в хипе), поэтому создание массива начинается

с выделения памяти под его элементы.
Элементами массива могут быть величины как значимых, так и ссылочных типов (в том числе массивы), например:
int[] w = new int[10]; // массив из 10 целых чисел
string[] z = new string[100]; // массив из 100 строк
Monster [] s = new Monster[5]; // массив из 5 монстров
double[,] t = new double[2, 10]; // прямоуг. массив 2х10
int[,,,] m = new int[2,2,2,2]; // 4-xмерный массив
int[][][] a = new int[2][][]; … // массив массивов массивов

Массив значимых типов хранит значения, массив ссылочных типов — ссылки на элементы.
Всем элементам при создании массива присваиваются значения по умолчанию: нули для значимых типов и null для ссылочных.

Слайд 85 ©Павловская Т.А. (НИУ ИТМО)
Одномерные массивы
Варианты описания массива:
тип[]

©Павловская Т.А. (НИУ ИТМО)Одномерные массивы Варианты описания массива:тип[] имя;тип[] имя =

имя;
тип[] имя = new тип [ размерность ];
тип[] имя

= { список_инициализаторов };
тип[] имя = new тип [] { список_инициализаторов };
тип[] имя = new тип [ размерность ] { список_инициализаторов };
Примеры описаний (один пример на каждый вариант описания, соответственно):
int[] a; // память под элементы не выделена
int[] b = new int[4]; // элементы равны 0
int[] c = { 61, 2, 5, -9 }; // new подразумевается
int[] d = new int[] { 61, 2, 5, -9 }; // размерность вычисляется
int[] e = new int[4] { 61, 2, 5, -9 }; // избыточное описание

Слайд 86 ©Павловская Т.А. (НИУ ИТМО)
Оператор foreach (упрощенно)
Применяется для перебора

©Павловская Т.А. (НИУ ИТМО)Оператор foreach (упрощенно)Применяется для перебора элементов массива. Синтаксис:foreach

элементов массива. Синтаксис:
foreach ( тип имя in имя_массива )

тело_цикла
имя задает локальную по отношению к циклу переменную, которая будет по очереди принимать все значения из массива, например:

int[] massiv = { 24, 50, 18, 3, 16, -7, 9, -1 };
foreach ( int x in massiv ) Console.WriteLine( x );



Слайд 87 ©Павловская Т.А. (НИУ ИТМО)
Программа в true style ☺
class

©Павловская Т.А. (НИУ ИТМО)Программа в true style ☺class Mas_1

Mas_1

// класс для работы с 1-мерным массивом
{
int[] a = { 3, 12, 5, -9, 8, -4 }; // для простоты слайда

public void PrintMas() // вывод массива
{ Console.Write("Массив: ");
foreach (int elem in a) Console.Write(" " + elem);
Console.WriteLine();
}

public long SumOtr() // cумма отрицательных элементов
{
long sum_otr = 0;
foreach (int elem in a)
if (elem < 0) sum_otr += elem;
return sum_otr;
}


Слайд 88 public int NumOtr()

public int NumOtr()     // кол-во отрицательных

// кол-во отрицательных элементов

{
int num_otr = 0;
foreach (int elem in a)
if (elem < 0) ++num_otr;
return num_otr;
}

public int MaxElem() // максимальный элемент
{
int max = a[0];
foreach (int elem in a) if (elem > max) max = elem;
return max;
}
}

©Павловская Т.А. (НИУ ИТМО)


Слайд 89 class Program

class Program         //

// класс-клиент
{ static void Main(string[] args)
{
Mas_1 mas = new Mas_1();
mas.PrintMas();

long sum_otr = mas.SumOtr();
if (sum_otr != 0) Console.WriteLine("Сумма отриц. = " + sum_otr);
else Console.WriteLine("Отриц-х эл-тов нет");

int num_otr = mas.NumOtr();
if (num_otr != 0) Console.WriteLine("Кол-во отриц. = " + num_otr);
else Console.WriteLine("Отриц-х эл-тов нет");

Console.WriteLine("Макс. элемент = " + mas.MaxElem());
}
}


©Павловская Т.А. (НИУ ИТМО)


Слайд 90 Пример анализа задания
Найти среднее арифметическое элементов, расположенных между

Пример анализа заданияНайти среднее арифметическое элементов, расположенных между минимумом и максимумомВарианты

минимумом и максимумом
Варианты результата:
выводится среднее арифметическое
выводится сообщение «таких элементов

нет» (мин. и макс. рядом или все элементы массива одинаковы)
Вопрос: если макс. или мин. эл-тов несколько?
Варианты тестовых данных:
минимум левее максимума
наоборот
рядом
более одного мин/макс
все элементы массива равны
все элементы отрицательные


©Павловская Т.А. (НИУ ИТМО)


Слайд 91 ©Павловская Т.А. (НИУ ИТМО)
Использование методов класса Array
static

©Павловская Т.А. (НИУ ИТМО)Использование методов класса Array static void Main()

void Main()
{

int[] a = { 24, 50, 18, 3, 16, -7, 9, -1 };
PrintArray( "Исходный массив:", a );
Console.WriteLine( Array.IndexOf( a, 18 ) );
Array.Sort(a); // Array.Sort(a, 1, 5);
PrintArray( "Упорядоченный массив:", a );
Console.WriteLine( Array.BinarySearch( a, 18) );
Array.Reverse(a); // Array.Reverse(a, 2, 4);
}
public static void PrintArray( string header, int[] a ) {
Console.WriteLine( header );
for ( int i = 0; i < a.Length; ++i )
Console.Write( "\t" + a[i] );
Console.WriteLine();
}

Слайд 92 Что вы должны уметь найти в массиве:
минимум/максимум [по

Что вы должны уметь найти в массиве:минимум/максимум [по модулю]номер минимума/максимума [по

модулю]
номер минимума/максимума [по модулю]
номер первого/второго/последнего положительного/отрицательного/нулевого эл-та
сумма/произведение/количество/сред. арифм-е положительных/отрицательных/нулевых

эл-тов

упорядочить массив НЕ методом пузырька.

анализировать все возможные варианты расположения исходных данных

©Павловская Т.А. (НИУ ИТМО)


Слайд 93 ©Павловская Т.А. (НИУ ИТМО)
Прямоугольные массивы
Прямоугольный массив имеет

©Павловская Т.А. (НИУ ИТМО)Прямоугольные массивы Прямоугольный массив имеет более одного измерения.

более одного измерения. Чаще всего в программах используются двумерные

массивы. Варианты описания двумерного массива:
тип[,] имя;
тип[,] имя = new тип [ разм_1, разм_2 ];
тип[,] имя = { список_инициализаторов };
тип[,] имя = new тип [,] { список_инициализаторов };
тип[,] имя = new тип [ разм_1, разм_2 ] { список_инициализаторов };
Примеры описаний (один пример на каждый вариант описания):
int[,] a; // элементов нет
int[,] b = new int[2, 3]; // элементы равны 0
int[,] c = {{1, 2, 3}, {4, 5, 6}}; // new подразумевается
int[,] c = new int[,] {{1, 2, 3}, {4, 5, 6}}; // разм-сть вычисляется
int[,] d = new int[2,3] {{1, 2, 3}, {4, 5, 6}}; // избыточное описание

Слайд 94 ©Павловская Т.А. (НИУ ИТМО)
Пример
Программа определяет:
среднее арифметическое всех

©Павловская Т.А. (НИУ ИТМО)ПримерПрограмма определяет: среднее арифметическое всех элементов;количество положительных элементов

элементов;
количество положительных элементов в каждой строке

для целочисленной матрицы размером

3 х 4

Слайд 95 ©Павловская Т.А. (НИУ ИТМО)

const int m = 3,

©Павловская Т.А. (НИУ ИТМО)const int m = 3, n = 4;int[,]

n = 4;
int[,] a = new int[m, n] {

{ 2,-2, 8, 9 },
{-4,-5, 6,-2 },
{ 7, 0, 1, 1 }
};
Console.WriteLine( "Исходный массив:" );
for ( int i = 0; i < m; ++i )
{ for ( int j = 0; j < n; ++j )
Console.Write( "\t" + a[i, j] );
Console.WriteLine();
}

Слайд 96 ©Павловская Т.А. (НИУ ИТМО)
int nPosEl;
for ( int i

©Павловская Т.А. (НИУ ИТМО)int nPosEl;for ( int i = 0; i

= 0; i < m; ++i )
{

nPosEl = 0;
for ( int j = 0; j < n; ++j )
if ( a[i, j] > 0 ) ++nPosEl;
Console.WriteLine( "В строке {0} {1} положит-х эл-в", i, nPosEl);
}

double sum = 0;
foreach ( int x in a ) sum += x; // все элементы двумерного массива!
Console.WriteLine( "Среднее арифметическое всех элементов: "
+ sum / m / n );

Слайд 97 ©Павловская Т.А. (СПбГУ ИТМО)
Строки типа string
Тип string

©Павловская Т.А. (СПбГУ ИТМО)Строки типа string Тип string предназначен для работы

предназначен для работы со строками символов в кодировке Unicode.

Ему соответствует базовый класс System.String библиотеки .NET.
Создание строки:
string s; // инициализация отложена
string t = "qqq"; // инициализация строковым литералом
string u = new string(' ', 20); // с пом. конструктора
string v = new string( a ); // создание из массива символов
// создание массива символов: char[] a = { '0', '0', '0' };

Слайд 98 ©Павловская Т.А. (СПбГУ ИТМО)
Операции для строк
присваивание (=);
проверка на

©Павловская Т.А. (СПбГУ ИТМО)Операции для строкприсваивание (=);проверка на равенство (==);проверка на

равенство (==);
проверка на неравенство (!=);
обращение по индексу ([]);
сцепление (конкатенация)

строк (+).

Строки равны, если имеют одинаковое количество символов и совпадают посимвольно.
Обращаться к отдельному элементу строки по индексу можно только для получения значения, но не для его изменения. Это связано с тем, что строки типа string относятся к неизменяемым типам данных.
Методы, изменяющие содержимое строки, на самом деле создают новую копию строки. Неиспользуемые «старые» копии автоматически удаляются сборщиком мусора.

Слайд 99 ©Павловская Т.А. (СПбГУ ИТМО)
Пример: разбиение текста на слова
StreamReader

©Павловская Т.А. (СПбГУ ИТМО)Пример: разбиение текста на словаStreamReader inputFile = new

inputFile = new StreamReader("example.txt");
string text = inputFile.ReadToEnd();

char[] delims =

".,;:!?\n\xD\xA\" ".ToCharArray();
string[] words = text.Split(delims,
StringSplitOptions.RemoveEmptyEntries);
foreach (string word in words) Console.WriteLine(word);

Console.WriteLine("Cлов в тексте: " + words.Length);

// слова, оканчивающиеся на «а»:
foreach (string word in words)
if (word[word.Length-1] == 'а') Console.WriteLine(word);



Слайд 100 ©Павловская Т.А. (СПбГУ ИТМО)
Регулярные выражения
Регулярное выражение — шаблон (образец),

©Павловская Т.А. (СПбГУ ИТМО)Регулярные выраженияРегулярное выражение — шаблон (образец), по которому выполняется

по которому выполняется поиск соответствующего ему фрагмента текста.

тег html:
<[^>]+>
российский номер автомобиля:
[A-Z]\d{3}[A-Z]{2}\d\dRUS
IP-адрес:
\d\d?\d?\.\d\d?\d?\.\d\d?\d?\.\d\d?\d?
Регулярные выражения предназначены для обработки текстовой информации и обеспечивают:
эффективный поиск в тексте по заданному шаблону;
редактирование, замену и удаление подстрок;
формирование итоговых отчетов по результатам работы с текстом.

Примеры упрощенные


Слайд 101 ©Павловская Т.А. (СПбГУ ИТМО)
Язык описания регулярных выражений
Язык описания

©Павловская Т.А. (СПбГУ ИТМО)Язык описания регулярных выраженийЯзык описания регулярных выражений состоит

регулярных выражений состоит из символов двух видов: обычных и

метасимволов.
Обычный символ представляет в выражении сам себя.
Метасимвол:
класс символов (например, любая цифра \d или буква \w)
уточняющий символ (например, ^).
повторитель (например, +).
Примеры:
выражение для поиска в тексте фрагмента «Вася» записывается с помощью четырех обычных символов «Вася»
выражение для поиска двух цифр, идущих подряд, состоит из двух метасимволов «\d\d»
выражение для поиска фрагментов вида «Вариант 1», «Вариант 2», …, «Вариант 9» имеет вид «Вариант \d»
выражение для поиска фрагментов вида «Вариант 1», «Вариант 23», «Вариант 719», …, имеет вид «Вариант \d+»


Слайд 102 ©Павловская Т.А. (СПбГУ ИТМО)
Метасимволы - классы символов

©Павловская Т.А. (СПбГУ ИТМО)Метасимволы - классы символов

Слайд 103 ©Павловская Т.А. (СПбГУ ИТМО)
продолжение таблицы

©Павловская Т.А. (СПбГУ ИТМО)продолжение таблицы

Слайд 104 ©Павловская Т.А. (СПбГУ ИТМО)
Повторители

©Павловская Т.А. (СПбГУ ИТМО)Повторители

Слайд 105 ©Павловская Т.А. (СПбГУ ИТМО)
Примеры простых регулярных выражений
целое

©Павловская Т.А. (СПбГУ ИТМО)Примеры простых регулярных выражений целое число (возможно, со

число (возможно, со знаком):
[-+]?\d+

вещественное число (может иметь

знак и дробную часть, отделенную точкой):
[-+]?\d+\.?\d*

российский номер автомобиля (упрощенно):
[A-Z]\d{3}[A-Z]{2}\d\dRUS

ip-адрес (упрощенно):
(\d{1,3}\.){3}\d{1,3}

Слайд 106 Поддержка регулярных выражений в .NET
Для поддержки регулярных выражений

Поддержка регулярных выражений в .NETДля поддержки регулярных выражений в библиотеку .NET

в библиотеку .NET включены классы, объединенные в пространство имен

System.Text.RegularExpressions.
Основной класс – Regex. Он реализует подсистему обработки регулярных выражений.
Подсистеме требуется предоставить:
Шаблон (регулярное выражение), соответствия которому требуется найти в тексте.
Текст, который требуется проанализировать с помощью шаблона.

См.:
http://msdn.microsoft.com/ru-ru/library/hs600312.aspx?ppud=4

©Павловская Т.А. (СПбГУ ИТМО)


Слайд 107 Методы класса Regex
позволяют выполнять следующие действия:
Определить,

Методы класса Regex позволяют выполнять следующие действия: Определить, встречается ли во

встречается ли во входном тексте шаблон регулярного выражения (метод

IsMatch).
Извлечь из текста одно или все вхождения, соответствующие шаблону регулярного выражения (методы Match или Matches).
Заменить текст, соответствующий шаблону регулярного выражения (метод Replace).
Разделить строку на массив строк (метод Split).

©Павловская Т.А. (СПбГУ ИТМО)


Слайд 108 using System;
using System.Text.RegularExpressions;
public class Example
{

using System; using System.Text.RegularExpressions; public class Example { public static void

public static void Main()
{ string[] values =

{ "111-22-3333", "111-2-3333"};
string pattern = @"^\d{3}-\d{2}-\d{4}$";
foreach (string value in values)
{ if (Regex.IsMatch(value, pattern))
Console.WriteLine("{0} is a valid SSN.", value);
else Console.WriteLine("{0}: Invalid", value);
} } }
// Вывод:
// 111-22-3333 is a valid SSN.
// 111-2-3333: Invalid

©Павловская Т.А. (СПбГУ ИТМО)

Пример использования Regex.IsMatch


Слайд 109 ©Павловская Т.А. (СПбГУ ИТМО)
Абстрактные структуры данных
Массив

©Павловская Т.А. (СПбГУ ИТМО)Абстрактные структуры данных Массив конечная совокупность однотипных величин.

конечная совокупность однотипных величин. Занимает непрерывную область памяти и

предоставляет прямой (произвольный) доступ к элементам по индексу.
Линейный список
Стек
Очередь
Бинарное дерево
Хеш-таблица (ассоциативный массив, словарь)
Граф
Множество

Слайд 110 ©Павловская Т.А. (СПбГУ ИТМО)
Контейнеры http://msdn.microsoft.com/ru-ru/library/ybcx56wz.aspx?ppud=4
Контейнер (коллекция) - стандартный

©Павловская Т.А. (СПбГУ ИТМО)Контейнеры http://msdn.microsoft.com/ru-ru/library/ybcx56wz.aspx?ppud=4Контейнер (коллекция) - стандартный класс, реализующий абстрактную

класс, реализующий абстрактную структуру данных.
Для каждого типа коллекции

определены методы работы с ее элементами, не зависящие от конкретного типа хранимых данных.
Использование коллекций позволяет сократить сроки разработки программ и повысить их надежность.
Каждый вид коллекции поддерживает свой набор операций над данными, и быстродействие этих операций может быть разным.
Выбор вида коллекции зависит от того, что требуется делать с данными в программе и какие требования предъявляются к ее быстродействию.
В библиотеке .NET определено множество стандартных контейнеров.
Основные пространства имен, в которых они описаны  — System.Collections, System.Collections.Specialized и System.Collections.Generic

Слайд 111 ©Павловская Т.А. (СПбГУ ИТМО)
Параметризованные коллекции (классы-прототипы, generics)
- классы,

©Павловская Т.А. (СПбГУ ИТМО)Параметризованные коллекции (классы-прототипы, generics) - классы, имеющие типы данных в качестве параметров

имеющие типы данных в качестве параметров


Слайд 112 Повторение: контейнеры и файлы
©Павловская Т.А. (СПбГУ ИТМО)
Queue
Stack
LinkedList
ArrayList
StringCollection
List
HashTable
SortedList
Dictionary
StringDictionary

Повторение: контейнеры и файлы©Павловская Т.А. (СПбГУ ИТМО)QueueStackLinkedListArrayListStringCollectionListHashTableSortedListDictionaryStringDictionary

Слайд 113 ©Павловская Т.А. (СПбГУ ИТМО)
Пример использования класса List
using System;
using

©Павловская Т.А. (СПбГУ ИТМО)Пример использования класса Listusing System;using System.Collections.Generic;namespace ConsoleApplication1{class Program

System.Collections.Generic;
namespace ConsoleApplication1{
class Program {
static void

Main() {
List lint = new List();
lint.Add( 5 ); lint.Add( 1 ); lint.Add( 3 );
lint.Sort();
int a = lint[2];
Console.WriteLine( a );
foreach ( int x in lint ) Console.Write( x + " ");
}}}

Слайд 114 ©Павловская Т.А. (СПбГУ ИТМО)
Общие принципы работы с файлами

©Павловская Т.А. (СПбГУ ИТМО)Общие принципы работы с файлами Чтение (ввод)  —


Чтение (ввод)  — передача данных с внешнего устройства в

оперативную память, обратный процесс — запись (вывод).
Ввод-вывод в C# выполняется с помощью подсистемы ввода-вывода и классов библиотеки .NET. Обмен данными реализуется с помощью потоков.
Поток (stream) — абстрактное понятие, относящееся к любому переносу данных от источника к приемнику. Потоки обеспечивают надежную работу как со стандартными, так и с определенными пользователем типами данных, а также единообразный и понятный синтаксис.
Поток определяется как последовательность байтов и не зависит от конкретного устройства, с которым производится обмен.
Обмен с потоком для повышения скорости передачи данных производится, как правило, через буфер. Буфер выделяется для каждого открытого файла.

Слайд 115 ©Павловская Т.А. (СПбГУ ИТМО)
Уровни обмена с внешними устройствами
Выполнять

©Павловская Т.А. (СПбГУ ИТМО)Уровни обмена с внешними устройствамиВыполнять обмен с внешними

обмен с внешними устройствами можно на уровне:

двоичного представления данных


(BinaryReader, BinaryWriter);

байтов
(FileStream);

текста, то есть символов
(StreamWriter, StreamReader).

Слайд 116 ©Павловская Т.А. (СПбГУ ИТМО)
Доступ к файлам
Доступ к файлам

©Павловская Т.А. (СПбГУ ИТМО)Доступ к файламДоступ к файлам может быть:последовательным -

может быть:
последовательным - очередной элемент можно прочитать (записать) только

после аналогичной операции с предыдущим элементом
произвольным, или прямым, при котором выполняется чтение (запись) произвольного элемента по заданному адресу.

Текстовые файлы позволяют выполнять только последовательный доступ, в двоичных и байтовых потоках можно использовать оба метода.

Прямой доступ в сочетании с отсутствием преобразований обеспечивает высокую скорость получения нужной информации.

Слайд 117 ©Павловская Т.А. (СПбГУ ИТМО)
Пример чтения из текстового файла

©Павловская Т.А. (СПбГУ ИТМО)Пример чтения из текстового файла  static void


static void Main() // весь файл

-> в одну строку
{ try
{
StreamReader f = new StreamReader( "text.txt" );
string s = f.ReadToEnd();
Console.WriteLine(s);
f.Close();
}
catch( FileNotFoundException e )
{
Console.WriteLine( e.Message );
Console.WriteLine( " Проверьте правильность имени файла!" );
return;
}
catch
{
Console.WriteLine( " Неопознанное исключение!" );
return;
}
}

Слайд 118 ©Павловская Т.А. (СПбГУ ИТМО)
Построчное чтение текстового файла

©Павловская Т.А. (СПбГУ ИТМО)Построчное чтение текстового файла 		  StreamReader f

StreamReader f = new StreamReader( "text.txt" );

string s;
long i = 0;

while ( ( s = f.ReadLine() ) != null )
Console.WriteLine( "{0}: {1}", ++i, s );
f.Close();

Слайд 119 ©Павловская Т.А. (СПбГУ ИТМО)
Чтение чисел из текстового файла

©Павловская Т.А. (СПбГУ ИТМО)Чтение чисел из текстового файла – вар. 1try

– вар. 1
try {
List list_int

= new List();
StreamReader file_in = new StreamReader( @"D:\FILES\1024" );
Regex regex = new Regex( "[^0-9-+]+" );
List list_string = new List(
regex.Split( file_in.ReadToEnd().TrimStart(' ') ) );
foreach (string temp in list_string)
list_int.Add( Convert.ToInt32(temp) );

foreach (int temp in list_int) Console.WriteLine(temp);
...
}
catch (FileNotFoundException e)
{ Console.WriteLine("Нет файла" + e.Message); return; }
catch (FormatException e)
{ Console.WriteLine(e.Message); return; }
catch { … }

Слайд 120 ©Павловская Т.А. (СПбГУ ИТМО)
Чтение чисел из текстового файла

©Павловская Т.А. (СПбГУ ИТМО)Чтение чисел из текстового файла – вар. 2try

– вар. 2
try {
StreamReader file_in

= new StreamReader( @"D:\FILES\1024" );
char[] delim = new char[] { ' ' };
List list_string = new List(
file_in.ReadToEnd().Split( delim,
StringSplitOptions.RemoveEmptyEntries ));
List list_int = list_string.ConvertAll(Convert.ToInt32);
foreach ( int temp in ist_int ) Console.WriteLine( temp );
...
}
catch (FileNotFoundException e)
{ Console.WriteLine("Нет файла" + e.Message); return; }
catch (FormatException e)
{ Console.WriteLine(e.Message); return; }
catch { … }

  • Имя файла: povorenie-materiala-1-semestra-osnovy-yazyka-s-osnovy-oop-tipy-i-struktury-dannyh.pptx
  • Количество просмотров: 153
  • Количество скачиваний: 0