Разработка модуля для выполнения операций с натуральными числами в 16-ричной системе счисления. Выбор и проработка программных средств
Содержание:
Введение
Системой счисления называют систему приемов и правил, позволяющих устанавливать взаимно-однозначное соответствие между любым числом и его представлением в виде совокупности конечного числа символов. Множество символов, используемых для такого представления, называют цифрами.
В зависимости от способа изображения чисел с помощью цифр системы счисления делятся на позиционные и непозиционные.
В непозиционных системах любое число определяется как некоторая функция от численных значений совокупности цифр, представляющих это число. Цифры в непозиционных системах счисления соответствуют некоторым фиксированным числам. Пример непозиционной системы – рассмотренная ранее римская система счисления. Древние египтяне применяли систему счисления, состоящую из набора символов, изображавших распространенные предметы быта. Совокупность этих символов обозначала число. Расположение их в числе не имело значения, отсюда и появилось название.
Исторически первыми системами счисления были именно непозиционные системы. Одним из основных недостатков является трудность записи больших чисел. Запись больших чисел в таких системах либо очень громоздка, либо алфавит системы чрезвычайно велик.
В вычислительной технике непозиционные системы не применяются.
Систему счисления называют позиционной, если одна и та же цифра может принимать различные численные значения в зависимости от номера разряда этой цифры в совокупности цифр, представляющих заданное число. Пример такой системы – арабская десятичная система счисления.
Количества и количественные составляющие, существующие реально могут отображаться различными способами. В общем случае в позиционной системе счисления число N может быть представлено как:
где b – основание системы счисления; n – цифры в интервале от 0 до b-1.
Основание позиционной системы счисления определяет ее название. В вычислительной технике применяются двоичная, восьмеричная, десятичная и шестнадцатеричная системы. В дальнейшем, чтобы явно указать используемую систему счисления, будем заключать число в скобки и в нижнем индексе указывать основание системы счисления.
Каждой позиции в числе соответствует позиционный (разрядный) коэффициент или вес.
Шестнадцатеричная система счисления (шестнадцатеричные числа) — позиционная система счисления по целочисленному основанию 16.
Обычно в качестве шестнадцатеричных цифр используются десятичные цифры от 0 до 9 и латинские буквы от A до F для обозначения цифр от 10 до 15, то есть (0, 1, 2, 3, 4, 5, 6, 7, 8, 9, A, B, C, D, E, F). Широко используется в низкоуровневом программировании и компьютерной документации, поскольку в современных компьютерах минимальной единицей памяти является 8-битный байт, значения которого удобно записывать двумя шестнадцатеричными цифрами. Такое использование началось с системы IBM/360, где вся документация использовала шестнадцатеричную систему, в то время как в документации других компьютерных систем того времени (даже с 8-битными символами, как, например, PDP-11 или БЭСМ-6) использовали восьмеричную систему.
Глава 1. Выбор и проработка программных средств
Для разработки данного проекта был выбран достаточно молодой и прогрессивно развивающийся язык C#. В качестве среды проектирования использовался свободно-распространяемый проект Mono, как бесплатный аналог Microsoft Visual Studio и средство разработки с помощью платформы .NET на не- Windows платформах.
"Си шарп" (официально C#) является новым объектно-ориентированным языком программирования, разработанным для максимально удобного использования всех возможностей платформы Microsoft.NET. Во многом является схожим с другими популярными объектно-ориентированными языками, такими как C++ и Java, но имеет свои особенности. Благодаря появлению нового свободного проекта Mono, в Linux появилась возможность разрабатывать приложения на C#.
Mono — программная платформа, позволяющая разработчикам достаточно просто создавать развитые кроссплатформенные приложения. Технология Mono разрабатывается в виде open source реализации технологии .NET Framework от Microsoft и поддерживает стандарты ECMA-334 (стандарт языка C#) и ECMA-335 (стандарт среды исполнения Common Language Runtime, CLI). Открытость указанных стандартов позволяет уменьшить проблемы создания кроссплатформенных приложений.
В настоящее время в рамках этого проекта реализованы два стандарта: язык программирования C# (Стандарт ECMA-334) и "инфраструктура обобщенного языка программирования" (CLI) (Стандарт ECMA-335). Обе спецификации были разработаны в корпорации Microsoft и представлены ECMA (Европейской Ассоциации Производителей Компьютеров) в октябре 2000 г. Формальное одобрение было получено в декабре 2001 г., и эти предложения становятся стандартами ISO (благодаря соглашению, существующему между ISO и ECMA).
Проект Mono спонсируется компанией Ximian — той самой, которая предоставила миру графический рабочий стол GNOME. Лидером проекта является мексиканский программист, главный технический директор компании Ximian — Miguel de Icaza. Специалисты, привлеченные к разработке проекта Mono, в очень короткое время проделали огромный объем работ.
В базовом варианте Mono состоит из нескольких компонентов:
- компилятор языка C# — компилятор с полной поддержкой версий 1.0 и 2.0 языка C#. Кроме того в последних версиях поддерживаются практически все возможности версии C# 3.0, а начиная с версии Mono 2.6 включена поддержка возможностей версии C# 4.0 (пока только как опция, полноценная поддержка заявлена в версии 2.8);
- среда исполнения Mono — состоит из среды исполнения (CLI) непосредственно, компилятора среды исполнения (Just-In-Time, JIT), генератора машинного кода (Ahead-Of-Time, AOT), загрузчика сборок, сборщика мусора, подсистемы управления многопоточностью и компонентов поддержки взаимодействия между сборками и COM (или аналогами в Linux, например XCOM);
- базовая библиотека классов — набор стандартных классов, совместимых с классами Microsoft .NET Framework;
- библиотека классов Mono — набор классов, поддерживающих дополнительные функции для разработки Linux-приложений. Например, классы для поддержки Zip, OpenGL, Cairo, Gtk+.
На представленной на рисунке 1.1 диаграмме показан путь, который проходит программа на языке C# от компиляции до исполнения.
Компилятор Mono C# поддерживает версии языков C# 1.0-4.0 (про совместимость с .NET 4.5 данных нет). Для создания кода можно использовать один из нескольких вариантов компилятора, в зависимости от потребностей:
- mcs — компилятор, поддерживающий версию 1.1 среды исполнения. Компилирует код на языке C# (без поддержки generic и всего, что с ним связано). Данный компилятор планируется исключить в версии Mono 2.8, как устаревший.
-gmcs — компилятор, поддерживающий версии от 2.0 до 3.5 среды исполнения и обладающий полной поддержкой C# 3.0.
- smcs — опциональный компилятор для создания Moonlight (аналог Microsoft Silverlight) приложений.
- dmcs — опциональный компилятор, реализованный в тестовом варианте в версии Mono 2.6 и планируемый к включению в версию 2.8. Поддерживает среду исполнения версии 4.0 и язык C# 4.0.
Рисунок 1.1 – Логическая модель работы C#-программы, написанной с использованием проекта Mono
Начиная с версии Mono 2.2 реализована поддержка классов компилятора Mono.CSharp.Evaluator (сборка Mono.Sharp.dll) для создания собственных сервисов компиляции.
Среда исполнения Mono поддерживает инфраструктуру промежуточного языка CLI (Common Language Infrastructure), соответствующую стандарту ECMA-335. Виртуальная машина среды исполнения допускает возможность запуска приложений и сборок, скомпилированных в других системах (например, возможно запускать в Linux без перекомпиляции приложения, созданные при помощи Microsoft Visual Studio для исполнения в Microsoft Windows).
Также, вместо использования виртуальной машины, среда исполнения может быть интегрирована в приложение с целью создания встраиваемой системы, не требующей установки Mono для запуска и обладающей высоким быстродействием. При этом, в приложение включаются только необходимые компоненты среды исполнения.
В среде Mono реализован Ahead-Of-Time (AOT) компилятор промежуточного языка. Цель этого компилятора в том, чтобы уменьшить время запуска программы и оптимизировать ее код, путем компиляции промежуточного языка CLI в машинный код. Аналогом в Microsoft .NET Framework является утилита Ngen. Для запуска приложения в этом режиме можно воспользоваться опцией --aot среды исполнения (также можно включить полную оптимизацию кода при помощи опцее -O=all).
В качестве сборщика мусора в данный момент используется Boehm's GC, однако в текущей разрабатываемой ветке SVN присутствует совершенно новый сборщик мусора, разработанный специально для Mono.
Глава 2. Проект программы
Проект программы представлен в виде четырех основных классов: класс Program, являющийся классом по умолчанию, содержащем в себе точку входа приложения (static void Main(string[] args)), класса HEX, описывающего основную логику создания и взаимодействия шестнадцатеричных чисел, а также оставшиеся два класса в пространстве имен HEXNumbers.test для проведения тестов и проверки правильности разработанного приложения: Sorting и Involution.
Приведем данные о представленных классах и опишем их сигнатуру.
Program
Этот класс содержит в себе только лишь точку входа в приложение, в котором вызываются два теста, заданных по условию технического задания: сортировка массива в порядке убывания и возведение шестнадцатеричного числа в степень, также представленную в шестнадцатеричном представлении.
HEX
Представление этого класса обозначено на рисунке 2.1.
Рисунок 2.1 – Класс HEX
Новый экземпляр класса НЕХ можно создать, передав в качестве аргумента конструктору либо число в десятичном представлении, либо строку, содержащую шестнадцатеричный вид числа.
Перегруженный метод ToString() возвращает строковый вариант текущего hex- значения.
Остальные статические методы класса НЕХ позволяет производить арифметические операции над объектами класса, а также конвертацию представлений: десятичное и шестнадцатеричное. Также отдельный статический метод позволяет провести проверку на корректность данного числа как шестнадцатеричного.
- CorrectHEXNumber – метод, позволяющий провести проверку шестнадцатеричного числа. Возвращает булево значение как результат проверки, принимает строковое выражение в качестве аргумента.
- ConvertFromHEX – позволяет провести конвертацию из шестнадцатеричного представления в десятичное. Метод перегружен и может принимать в качестве аргумента строковую константу либо объект типа НЕХ. Метод возвращает значение типа int.
- ConvertFromDecimal – проводит конвертацию числа из десятичной системы счисления. Метод принимает в качестве аргумента объект типа int, а возвращаемое значение – HEX.
- «operator +», «operator –«, «operator *», «operator /» – статические операторы, проводящие арифметические операции. Все методы возвращают значение типа HEX, в качестве аргументов принимаются два аргумента того же типа.
Оставшийся скрытый метод предназначается для проведения проверки числа на совместимость с шестнадцатеричным представлением и генерацию исключения в случае, если проверка не проходит. Этот метод используется во всех членах, где в качестве аргумента используется строковая константа, которая после используется для создания нового НЕХ-объекта.
Sorting
Статический класс, находящийся в пространстве имен HEXNumbers.test предназначен для решения задачи сортировки массива по убыванию. Единственный публичный метод Start начинает тестирование. Для более компактного и осмысленного прочтения кода весь процесс тестирования был разнесен на методы:
- creating – метод, добавляющий в динамический масив заданное параметром количество случайных шестнадцатеричных чисел;
- showArray и showArrayDec – методы, выводящие в консоль представление массива в шестнадцатеричном и десятичном соответственно представлении элементы массива, созданном ранее;
- sortList – производит сортировку массива с помощью указанного правила. Метод возвращает число типа int для вывода в консоль интервала времени в миллисекундах, затраченного на выполнение сортировки.
Involution
Оставшийся статический класс из пространства имен HEXNumbers.test, он позволяет возвести указанное число в указанную степень, представленных в шестнадцатеричном представлении.
Так же, как и в классе Sorting, публичный метод Start начинает тестирование. Инкапсулированный метод creatingNumbers предоставляет пользователю возможность ввести основание и степень для вычислений с проведением соответствующих проверок.
Структурная схема разработанного приложения представлена на рисунке 2.2.
Рисунок 2.2 – Структурная схема приложения HEXNumbers
Глава 3. Описание алгоритмов и текст программы
3.1 Создание и конвертация шестнадцатеричных чисел
Конструктор класса HEX перегружен и может принимать как число в десятичном представлении, так и строку, содержащую шестнадцатеричный вариант числа.
public HEX(int decNumber)
{ _number = decNumber; }
public HEX(string hexNumber)
: this(ConvertFromHEX(hexNumber))
{}
_number является скрытым членом типа int, который содержит десятичное представление создаваемого числа. В случае первого конструктора аргумент просто присваивается инкапсулированному члену. При применении перегруженного варианта конструктора к члену _number присваивается результат статического метода ConvertFromHEX.
public static int ConvertFromHEX(string hex)
{
ThrowExceprtionIfNotValidHEX(hex);
return int.Parse(hex, NumberStyles.HexNumber);
}
В этом случае производится проверка на правильность указания шестнадцатеричного числа в строке с помощю метода ThrowExceprtionIfNotV alidHEX.
static void ThrowExceprtionIfNotValidHEX(string hex)
{
if (!CorrectHEXNumber(hex)) throw new ApplicationException();
}
Проверка производится с помощью публичного статического метода CorrectHEXNumber. Если проверка оказывается провальной, вызывается исключение типа ApplicationException, как безопасного типа исключения для системы.
public static bool CorrectHEXNumber(string hex)
{
return HEXExpression.Match(hex).Value == hex;
}
Для проведения проверки используется регулярное выражение, с помощью метода можно возвратить ту часть строки, которая удовлетворяет заданному шаблону. В данном случае проводится проверка на равенство исходной строки и результата сравнения регулярного выражения.
Регулярное выражение, которое определяет символы шестнадцатеричного представления числа, создается следующим образом:
static Regex HEXExpression;
HEXExpression = new Regex("[0-9a-fA-F]+");
Для присваивания значения члену _number используется перегруженный метод int.Parse, в параметрах которого указывается строка, содержащая нужное число, и система счисления, которая используется в представлении.
Открытый рефлектором метод Parse выглядит следующим образом.
public static int Parse(string s, NumberStyles style)
{
NumberFormatInfo.V alidateParseStyleInteger(style);
return Number.ParseInt32(s, style, NumberFormatInfo.CurrentInfo);
}
internal static unsafe int ParseInt32(string s, NumberStyles style, NumberFormatInfo info)
{
byte* stackBuffer = stackalloc byte[114];
Number.NumberBuffer number = new Number.NumberBuffer(stackBuffer);
int num = 0; Number.StringToNumber(s, style, ref number, info, false);
if ((style & NumberStyles.AllowHexSpecifier) != NumberStyles.None)
{
if (!Number.HexNumberToInt32(ref number, ref num)) throw new OverflowException (Environment.GetResourceString ("Overflow_Int32"));
} else if (!Number.NumberToInt32(ref number, ref num))
throw newOverflowException(Environment.GetResourceString("Overflow_Int32"));
return num;
}
Метод ConvertFromHEX перегружен и может иметь следующее представление.
public static int ConvertFromHEX(HEX hex)
{
return ConvertFromHEX(hex.ToString());
}
Преобразование из десятичного представления в шестнадцатеричное обеспечивается следующим кодом.
public static HEX ConvertFromDecimal(int dec)
{
return new HEX(dec.ToString("X"));
}
Метод ToString целочисленного типа данных (int) позволяет преобразовать число в форматированную строку, с форматом, указанным в качестве аргумента метода. Сам метод ToString(string) выглядит так, как представлено в коде ниже.
public string ToString(string format)
{
return Number.FormatInt32(this, format, NumberFormatInfo.CurrentInfo);
}
3.2 Арифметические операции HEX
По условию задания класс должен обеспечивать следующие математические операции над HEX-числами:
- сложение;
- вычитание;
- умножение;
- деление.
Для выполнения этих действий были разработаны статические операторы типа HEX, которые преобразовали аргумент типа HEX в десятичный вид, далее выполнялись необходимые математические действия, а дальше конечный результат преобразовывался обратно в шестнадцатеричное представление.
Представим код разработанных операторов.
public static HEX operator +(HEX h1, HEX h2)
{ return new HEX(h1._number + h2._number); }
public static HEX operator -(HEX h1, HEX h2)
{ return new HEX(h1._number - h2._number); }
public static HEX operator *(HEX h1, HEX h2)
{ return new HEX(h1._number * h2._number); }
public static HEX operator /(HEX h1, HEX h2)
{ return new HEX(h1._number / h2._number); }
Так как операторы принадлежит тому типу данных, над которым происходят операции, у методов есть доступ к скрытым данным, в данном случае это член _number.
3.3 Сортировка чисел
Для пользователя статический класс для сортировки массива данных типа HEX представлен единственным методом Start. Код этого класса для удобства чтения и модификаций разбит на несколько частей (методов) и выглядит так, как показано ниже.
public static void Start(int count)
{
Console.WriteLine(string.Format("создание массива из {0} случайных HEX-чисел:", count));
creating(count);
showArray();
Console.Write("\nсортировка массива...");
Console.WriteLine(string.Format("{0} ms", sortList())); Console.WriteLine("\nрезультат в шестнадцатиричном представлении:"); showArray(); Console.WriteLine("\nрезультат в десятичном представлении:"); showArrayDec(); Console.WriteLine("\nнажмите любую клавишу для завершения..."); Console.ReadKey();
}
Аргумент count определяет количество чисел в динамическом массиве, который будет содержать данные, предназначенные для сортировки.
Все действия класса оповещаются соответствующими подсказками в консоли. Первым этапом является создание массива в коде creating.
static List<HEX> _array; static void creating(int count) {
_array.Clear(); for (int i = 0; i < count; i++)
_array.Add(new HEX(_random.Next(byte.MaxValue))); }
Сам массив представляет собой динамическую коллекцию объектов типа HEX. Особенностью такого выбора явился широкий спектр возможностей данного типа коллекций. В частности, размер коллекции не является фиксированным, что удобно при создании массивов, истинное число членов которого не может быть неизвестно заранее, или блоки данных могут добавляться в несколько заходов. Также интерфейсы IList и IList<T> позволяют конвертировать коллекцию в массив типа T[], производить сортировку по заданному алгоритму, динамически добавлять и удалять данные, производить поиск по определенному выражению и так далее.
Метод showArray выводит данные массива на консоль. Также присутствует похожий метод showArrayDec, который выводит данные этого же массива, но в десятичном представлении. Код этих методов представлен ниже.
static void showArray()
{
foreach (HEX h in _array) Console.Write(string.Format("{0}, ", h.ToString()));
Console.WriteLine();
}
static void showArrayDec()
{
foreach (HEX h in _array) Console.Write(string.Format("{0}, ", HEX.ConvertFromHEX(h.ToString())));
Console.WriteLine();
}
Оба метода используют для вывода форматированную строку, которая создается методом string.Format. Использование этого метода позволяет создавать новый объект строчного типа в одну строку без создания «временных» строковых констант и конкатенаций строк. Такой способ, как известно, существенно экономит ресурсы управляемой кучи .NET. Для перебора всех значений массива используется итератор foreach, который поддерживается типом данных List<T>.
Последним шагом является сортировка массива, а также вывод данных на консоль. Сортировка производится с помощью метода sortList, который, к тому же, возвращает количество занятого процессом времени в миллисекундах.
static long sortList()
{
long time = DateTime.Now.Ticks;
_array.Sort((h1, h2) =>
{
int _h1 = HEX.ConvertFromHEX(h1.ToString()),
_h2 = HEX.ConvertFromHEX(h2.ToString());
return _h1 == _h2 ? 0 : _h1 > _h2 ? -1 : 1;
});
return (DateTime.Now.Ticks - time) / 10000;
}
Сортировка массива производится по заданному в параметрах метода Sort делегата возвращаемому значению. Начиная с версии .NET Framework 3.5 пользователю предоставляется возможность оперировать лямбда-выражениями, которые во многих случаях заменяют многострочные операции создания и инициализацию предикатов и делегатов.
Сама сортировка коллекций данных выполняется по следующему принципу: если значения двух объектов равны, делегатом возвращается значение 0, если первый операнд больше второго, возвращается 1 и в противоположном случае – -1. Так как по условию задания задана сортировка по убыванию, условия возврата значений 1 и -1 необходимо поменять местами.
Для упрощения записи использовался тринарный оператор ?:, который заменяет присваивание данных в конструкции if-else.
Блок-схема алгоритма сортировки объектов класса HEX представлена на рисунке 3.1.
Рисунок 3.1 – Блок-схема алгоритма сортировки объектов HEX
3.4 Возведение в степень
Класс, позволяющий возвести число в степень, указанные в шестнадцатеричном виде, также представляет из себя метод Start(), который содержит основную логику действия.
public static void Start()
{
creatingNumbers();
Console.WriteLine(string.Format("число '{0}' будет возведено в степень '{1}'", _number, _power));
Console.WriteLine(string.Format("результат в шестнадцатеричном представлении: {0}", _result
new HEX((int)Math.Pow(HEX.ConvertFromHEX(_number.ToString()), HEX.ConvertFromHEX(_power.ToString())))));
Console.WriteLine(string.Format("результат в десятичном представлении: {0}", HEX.ConvertFromHEX(_result.ToString())));
Console.WriteLine(string.Format("нажмите любую клавишу для завершения...{0}", Console.ReadKey()));
}
Вторым и последним методом в классе является метод creatingNumbers, содержащий в себе интерфейс ввода пользователем необходимых чисел и функции их проверки.
Для начала пользователю предлагается ввести необходимые число и показатель степени с консоли. Следующим этапом является проверка правильности введенного шестнадцатеричного числа методом HEX.CorrectHEXNumber. Если обе проверки прошли успешно, инициализируются соответствующие HEX-члены класса, которые далее, в методе Start, участвуют в вычислениях.
Результат вычислений записывается в объект _result и подсчитывается с использованием стандартного класса Math и его метода, позволяющего произвести подсчет степени, Pow, который принимает два числа типа double, или совместимые с ним, и возвращает тоже тип double, который после явно приводится к целочисленному типу данных.
static HEX _number, _power, _result; static void creatingNumbers()
{
string number, power; do
{
Console.Clear(); Console.Write("введите число, возводимое в степень в HEX-представлении: ");
number = Console.ReadLine();
Console.Write("введите степень в HEX-представлении: ");
power = Console.ReadLine();
} while (!(HEX.CorrectHEXNumber(number) && HEX.CorrectHEXNumber(power)));
_number = new HEX(number);
_power = new HEX(power);
}
Блок-схема алгоритма возведения числа в степень представлена на рисунке 3.2.
Правильность расчетов, производимых разработанными классами, определяется проверочными тестами в разделе 4 данной работы.
Рисунок 3.2 – Блок-схема алгоритма возведения числа в степень
Глава 4. Тестирование и анализ результатов работы программы
Первым тестом при запуске приложения запускается сортировка массива из 100 случайных чисел. Результат работы программы представлен на рисунке 4.1.
Рисунок 4.1 – Сортировка массива
Как видно на рисунке, данные отсортированы по убыванию от 253 до 1, а на процесс сортировки ушло 20 миллисекунд.
После нажатия клавиши происходит переход к тесту возведения числа в степень. И первым пользователю предлагается ввести число, которое нужно возвести в степень, и сам показатель степени.
В качестве теста введем неверные данные (“az” и “-15”). Так как программа не приняла один из ответов (а в нашем случае оба) правильными, данные не записываются, и предлагается повторить попытку еще раз.
Введем для числа, возводимого в степень значение 10, что соответствует шестнадцатеричному представлению «А», а для показателя степени – 4, в hex-виде значение будет таким же.
Приложение оповестило, что число «А» будет возведено в степень «4» и представила результаты – в десятичном представлении это 10000, в представлении hex – 2710.
Рисунок 4.2 – Ввод неверных данных в окно тестирования
Рисунок 4.3 – Возведение А в степень 4
В качестве проверки на правильность расчетов воспользуемся стандартным Windows-калькулятором, в котором есть возможность конвертировать текущее число в различные системы счисления. 10000 в представлении hex отображена на рисунке 4.4.
Рисунок 4.4 – Проверка правильности расчетов стандартными средствами
Заключение
В результате выполненной работы был представлен модуль, позволяющий проводить с числами в шестнадцатеричном представлении различные математические операции: сложение, вычитание, умножение и деление. Также этот модуль позволяет конвертировать числа в двустороннем порядке – из десятичной системы счисления в шестнадцатеричную и наоборот. Отдельной функцией, представленной пользователю, реализована проверка на правильность введенного числа в hex-представлении. Модуль выполнен как класс HEX с возможностью создания новых экземпляров, в котором также присутствуют статические методы.
Используя разработанный класс были выполнены поставленные задачи: сортировка заданного массива в порядке убывания, а также возведение числа в степень с указанием данных в шестнадцатеричном представлении. Результаты обоих задач выводятся как в десятичном виде, так и в виде hex-чисел.
Для представления работы классов, а также оценки правильности результатов, были проведены тесты, результаты которых были представлены и проверены.
Для разработки проекта использовался платформа .NET и поддерживаемый ею язык программирования C#. В качестве IDE использовался open-source проект Mono.
Список использованной литературы
1. Троелсен Э. Язык программирования C# 2010 и платформа .NET 4.0, 5-е изд.: Пер. с англ. – М.: ООО «И.Д.Вильямс», 2011. – 1392 с.: ил. – Парал. тит. англ.
2. Ватсон К. C#. – М.: Издательство «Лори», 2001. – 879 с.: ил.
3. Шилдт Г. Полный справочник по C#.: Пер. с англ. – М.: Издательский дом «Вильямс», 2004. – 752 с.: ил. – Парал. тит. англ.
4. Фаулер М. Рефакторинг: улучшение существующего кода. – Пер. с англ. – СПб.: Символ-Плюс, 2003. – 432 с.: ил.
- Анализ деятельности складского учета, проектированние информационной системы в процесс работы склада.
- Проектирование реализации операций бизнес-процесса «Складской учет»
- Система защиты информации в банковских системах РФ
- Предмет и метод гражданского права)
- Выбор стиля руково дства в организации
- Совершенствованию маркетинговой деятельности предприятия на основе результатов маркетингового исследования ООО «Пашковский хлеб»
- Виды юридических лиц
- Изучение понятия и критериев института несостоятельности (банкротства).
- Понятие, принципы и основания юридической ответственности за правонарушения в сфере предпринимательской деятельности..
- ТЕХНОЛОГИЯ РАБОТЫ С ЖАЛОБАМИ ГОСТЕЙ в гостинице хилтон ленинградская на примере ресторана джанус
- Графические методы представления расписания проекта
- Автоматизация документооборота предприятия (Компания “Family Hobby”)