Раздел 4. Коллективная разработка по 


Мы поможем в написании ваших работ!



ЗНАЕТЕ ЛИ ВЫ?

Раздел 4. Коллективная разработка по



Тема 4.1 Категории специалистов занятых разработкой и эксплуатацией программ

Основная категория специалистов это программист (Programmer) они не однородны по уровню квалификации, а также характеру своей деятельности.

Программисты делятся на системных и прикладных

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

2. Прикладной программист (Application programmer) осуществляет разработку и отладку программ для решения функциональных задач. В условиях созданиях больших по масштабу и функциям обработки программ появляется квалификация – программист-аналитик (programmer -analyst) который анализирует и проектирует комплекс взаимосвязанных программ для реализации предметной области.

3. Системный программист (system/software programmer, tool smith) занимается разработкой, эксплуатацией и сопровождением системного программного обеспечения, поддерживающего работоспособность компьютера и создания среды для выполнения программ обеспечивающих реализацию функциональных задач.

4. Администратор базы данных обеспечивает работу с данными многих приложений организует поддержку базы данных.

5. Возможна эксплуатация программ квалифицированным и программистами или специально обученными техническими работниками - оператор ЭВМ.

6. Основным потребителем служит конечный пользователь (end user) он не является специалистом в области программирования и может иметь элементарные навыки работы с ПК. Такая квалификационная характеристика пользователя ПП влияет на спецификацию требований к создаваемым программам, интерфейсам, формам машинных документов, технологии решения задач на ЭВМ.

Рисунок 1- Схема взаимодействия специалистов связанных с созданием

и эксплуатацией программ

 

 

Технологии коллективной разработки

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

Авторская разработка

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

Этот принцип был достаточно широко распространен в 70-80-е годы XX века. Сейчас он применяется редко [Кулаичев 1999]. Примерами авторских разработок являются операционная система Диспак (В.Ф. Тюрин), текстовый редактор Лексикон (Е. М. Веселов), трансляторы с языков Algol-68 (П. Наур) и Pascal (H. Вирт).

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

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

По данным А. П. Кулаичева [Кулаичев 1999], авторская разработка может выигрывать по производительности в тридцать и более раз у коллективной разработки, что достигается за счет:

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

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

Объем программного продукта, выполненного методом авторской разработки, в 5-20 раз меньше по сравнению с индустриальными аналогами.

Авторская разработка предполагает достижение профессионального успеха, известности и славы в одиночку. Такое вполне реально, следует только правильно выбрать профессиональную "нишу", область ведения разработки.

Коллективная разработка

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

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

Технические командные роли

Равноправные соисполнители

Бригада равноправных соисполнителей обычно состоит из специалистов, занимающихся примерно подобными задачами в рамках одного проекта. Естественно, специализаций в рамках одной бригады может быть несколько. В разд. 1.7.6.2 уже приводился примерный состав такой бригады разработчиков. Напомним его:

· инженеры-разработчики (специалисты по инженерии программирования и программисты);

· технические писатели;

· инженеры тестирования;

· инженеры качества;

· специалисты по сопровождению продукта;

· специалисты по продажам продукта.

Тип работы определяет содержание и природу выполняемой работы. Приведем список типов работ и областей специализации на основе классификации Конгер [Conger 1994].

· Разработка приложений.

o Программист.

o Специалист по инженерии программирования.

o Специалист по инженерии знаний.

· Работа с приложениями.

o Специалист по приложениям.

o Администратор данных.

o Администратор базы данных.

· Техническая поддержка.

o Системный администратор.

o Сетевой администратор.

o Администратор коммуникаций,

· Обеспечение качества продукта.

o Технический писатель.

o Инженер тестирования.

o Инженер качества.

· Маркетинг.

o Специалист по сопровождению продукта.

o Специалист по продажам продукта.

· Системное интегрирование.

o Системный интегратор.

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



Поделиться:


Последнее изменение этой страницы: 2021-12-15; просмотров: 183; Нарушение авторского права страницы; Мы поможем в написании вашей работы!

infopedia.su Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав. Обратная связь - 3.140.198.173 (0.048 с.)