Запись урока:
Часть 1
[vk]http://vk.com/video_ext.php?oid=-66674957&id=167885989&hash=05201124f4ff1c84&hd=3[/vk]
Часть 2
[vk]http://vk.com/video_ext.php?oid=-66674957&id=167885995&hash=c70bf43c89e43ea0&hd=3[/vk]
Темы занятия:
- Контроль версий при помощи TortoiseHg.
- Отличие фундаментальных (int, double и т.д.) типов данных от нефундаментальных (DateTime, TimeSpan). Работа с датой-временем (см. справочник C# DateTime и TimeSpan).
- Массивы: цель использования, инициализация (стр. 178 Шилдта или см. справочник C# "массивы").
- Контейнеры list<>: принцип работы, отличие от массивов (см. справочник C# List<>).
- Работа с файлами (FileStream - стр. 441, StreamReader - стр. 451, или см. доп. файл во вложениях).
- Создание пользовательского класса.
- Методы (стр. 155 Шилдта), конструкторы (стр. 166 Шилдта) и свойства класса (стр. 313 Шилдта) (либо по классам см. доп. файл во вложениях).
Домашнее задание:
Модифицировать метод SmaIndicator.Add() таким образом, чтобы избавиться от цикла при подсчёте.
Изробразить любым доступным способом иерархию классов:
- List, Set, Dictionary,
- SortedList, SortedSet, SortedDictionary,
- LinkedList, Queue, Stack, HashSet
- Прочитать в книге главу, посвящённую классам (глава 6).
Полезные материалы:
- Исключения.
- Оператор цикла foreach - стр. 139 Шилдта
Решение домашней задачи:
public void Add(decimal newValue)
{
// 1. Получить старое значение суммы
decimal sum = Value * _buffer.Count;
// 2. Добавить в неё новое значение (+ в буфер)
sum += newValue;
_buffer.Enqueue(newValue);
// 3. Вычесть самое старое значение (- из буфера), если надо
if (_buffer.Count > Length)
sum -= _buffer.Dequeue();
// 4. Получить новое среднее
Value = sum / _buffer.Count;
// (sum*Len+x-y)/Len => sum + (x-y)/Len
}
Вложения:
Исходные коды