Дефрагментация мозга. Софтостроение изнутри | страница 61
Краткий словарь для начинающего проектировщика
Основная задача проектировщика – поиск простоты. Очень просто делать сложно, но очень сложно сделать просто. Начинающий проектировщик осознает это сам со временем, а пока нужно учиться элементарным понятиям для понимания, что же хотел сказать коллега по проекту на самом деле.
• «Это был плохой дизайн». Это спроектировано не мной.
• «By design» (так спроектировано). Ошибка проектирования, стоимость исправления которой уже сравнима с переделкой части системы.
• «Это не ошибка, а особенность (not a bug but a feature)». Прямое следствие из «by design».
• «Это может ухудшить производительность». Не знаю и знать не хочу ваши альтернативные решения.
• «Нормализация не догма». Потом разберёмся с этими базами данных, когда время будет.
• «Это наследуемый модуль». Этот кусок со многими неявными зависимостями проектировали достаточно давно, скорее всего стажёры.
• «Постановка задачи тоже сложна». Ума не приложу, откуда возникли эти десятки тысяч строк спагетти-кода.
• «Сроки очень сжатые». Мы давно забили болт на проектирование.
• «Наши модульные тесты покрывают почти 100 % кода». А функциональными тестами пусть занимается заказчик.
• «В нашей системе много компонентов». Установку и развёртывание системы могут сделать только сами разработчики.
Слоистость и уровни
Разбираться в слоях и уровнях должны не только разработчики КИС, то есть «скелета», но и те программисты, которые будут наращивать на него свои приложения. Иначе велик риск ненароком прилепить бицепс вместо ягодичных мышц или наоборот.
Определение автоматизированной информационной системы (АИС) складывается из трёх основных её компонентов: людей, информации и компьютеров. Любая АИС – это люди, использующие информационную технологию средствами автоматизации [9]. И КИС не исключение.
В публикациях по софтостроению часто используются понятия слоёв и уровней программной системы. В англоязычной среде соответствующие термины —
layer и level. На физическом уровне реализующий слой компонент системы называется звеном – tier. Чтобы не запутаться в употреблении терминологии, нам следует чуть подробнее вглядеться во внутреннее устройство АИС.
Любая автоматизированная информационная система может быть рассмотрена с трёх точек зрения проектировщика:
• концептуальное устройство[93];
• логическое устройство;
• физическое устройство.
Концептуальное устройство
Концептуальное устройство АИС составляют всего три слоя.