Студопедия — UML-диаграмма классов
Студопедия Главная Случайная страница Обратная связь

Разделы: Автомобили Астрономия Биология География Дом и сад Другие языки Другое Информатика История Культура Литература Логика Математика Медицина Металлургия Механика Образование Охрана труда Педагогика Политика Право Психология Религия Риторика Социология Спорт Строительство Технология Туризм Физика Философия Финансы Химия Черчение Экология Экономика Электроника

UML-диаграмма классов






Диаграмма классов UML позволяет обозначать отношения между классами и их экземплярами. Отношения между классами любого объектно-ориентированного приложения можно представить в виде такой структурной схемы (Рисунок 1):

Рисунок 1

 


 

Необходимо построить UML-диаграмму классов, а затем отразить ее в объектно-ориентированном коде.

Отношение обобщение – это наследование. Наследование объектом членов другого класса представлено в явном виде в классе Storage_Coursework.UserControls.Material. Это пользовательский элемент управления, унаследовавший свойства и методы класса System.Windows.Forms.UserControl, позволяющий «визуализировать» объект класса Storage_Coursework.Objects.Material. Но наследование происходит в неявном виде. Объект Storage_Coursework.Objects.Material m передается в конструктор пользовательского элемента управления и становится одним из его членов. При построении элемента управления в методе SetupControls() происходит присвоение значений свойствам визуальных элементов от свойств этого члена. В коде метода SetupControls() это выглядит так:

lbMaterialName.Text = material.MaterialName;

т.е. визуальный объект lbMaterialName получает новое значение свойства Text от родительского (хотя наследование не явное) класса material (свойство MaterialName).

Наследование можно представить в виде схемы (Рисунок 2):

Рисунок 2

Отношение ассоциация показывает отношения между объектами-экземплярами класса. Пример бинарной ассоциации можно рассмотреть в отношении классов User и Role пространства имен Storage_Coursework.Objects

Предоставление доступа к приложению осуществляется на основании совокупности прав, закреплённых за ролью. Каждый пользователь имеет только одну роль в приложении, а значит, имеет набор прав доступа, определённых этой ролью. Таким образом между классами User и Role можно установить связь «один к одному» (Рисунок 3).

Рисунок 3

В свойстве User.UserRole получаем единственную роль пользователя так (Листинг 1):

public Role UserRole { get { return Storage_Coursework.Providers. RoleProvider.GetUserRole(this.UserID); } }
Листинг 1


Каждая роль содержит набор разрешений. Соответственно, связь между классами Role и RoleAccess будет «Один ко многим». Такое отношение называется N-арной ассоциацией (Рисунок 4).

Рисунок 4

 

Класс RoleAccess отвечает за права (разрешения), закреплённые за ролями. Например, ролям «администратор», «работник склада» и «прораб» дано разрешение на просмотр списка строительных материалов на складе. Кодовое название (AccessCode) этого разрешения StorageView. Проверку возможности просмотра списка материалов можно реализовать методом (Листинг 2):

public bool ExistAccess(string accessCode) { return Storage_Coursework.Providers.RoleProvider. ExistAccess(this.RoleID, accessCode); }
Листинг 2

 


Таким образом можно исключить класс RoleAccess из набора классов приложения, а получать наличие разрешения для текущего пользователя на выполнение той или иной операции в системе можно таким путем:

bool access = currentUser.UserRole.ExistAccess(“ShowAdminPanel”)

 

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


 

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

Рисунок 5

 

Отношения 1, 4 – бинарная ассоциация;

Отношение 2 – N-арная ассоциация;

Отношение 3 – обобщение.

 

Классы, описывающие пользователя и права доступа, и классы, описывающие материалы и склад не взаимосвязаны.







Дата добавления: 2015-06-15; просмотров: 718. Нарушение авторских прав; Мы поможем в написании вашей работы!



Кардиналистский и ординалистский подходы Кардиналистский (количественный подход) к анализу полезности основан на представлении о возможности измерения различных благ в условных единицах полезности...

Обзор компонентов Multisim Компоненты – это основа любой схемы, это все элементы, из которых она состоит. Multisim оперирует с двумя категориями...

Композиция из абстрактных геометрических фигур Данная композиция состоит из линий, штриховки, абстрактных геометрических форм...

Важнейшие способы обработки и анализа рядов динамики Не во всех случаях эмпирические данные рядов динамики позволяют определить тенденцию изменения явления во времени...

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

Виды сухожильных швов После выделения культи сухожилия и эвакуации гематомы приступают к восстановлению целостности сухожилия...

КОНСТРУКЦИЯ КОЛЕСНОЙ ПАРЫ ВАГОНА Тип колёсной пары определяется типом оси и диаметром колес. Согласно ГОСТ 4835-2006* устанавливаются типы колесных пар для грузовых вагонов с осями РУ1Ш и РВ2Ш и колесами диаметром по кругу катания 957 мм. Номинальный диаметр колеса – 950 мм...

Классификация и основные элементы конструкций теплового оборудования Многообразие способов тепловой обработки продуктов предопределяет широкую номенклатуру тепловых аппаратов...

Именные части речи, их общие и отличительные признаки Именные части речи в русском языке — это имя существительное, имя прилагательное, имя числительное, местоимение...

Интуитивное мышление Мышление — это пси­хический процесс, обеспечивающий познание сущности предме­тов и явлений и самого субъекта...

Studopedia.info - Студопедия - 2014-2024 год . (0.008 сек.) русская версия | украинская версия