Поскольку средства, используемые для программирования, очень сильно влияют на производительность труда, от них также сильно зависит успех или неудача проекта. В предыдущих главах мы уже обсуждали этот вопрос.
Среди самых основных инструментов можно упомянуть вычислительные машины, формирующие рабочие программы, программное обеспечение, выполняемое на этих машинах, людей, разбирающихся в вопросах поддержания рабочего состояния инструментальных средств, системы тестирования, а также механизмы управления конфигурацией.
Часто приходится сталкиваться с проблемой недостаточной мощности центрального процессора, на котором должно работать инструментальное программное обеспечение. Этот недостаток приводит к увеличению времени ожидания решения и снижению производительности труда. Преодолеть беды, вызванные плохим инструментарием, удается редко; графики из-за него срываются, а затраты увеличиваются.
Тем, кто отваживается первым использовать новый язык программирования или операционную систему, это обычно очень дорого достается.
Наиболее ответственным можно считать решение купить готовое программное обеспечение или построить его самому. Обсудим сначала само это решение и последствия, к которым оно приводит, а затем посмотрим, из каких компонент оно состоит. (См. рис. 6.23.)
Выбор — покупать или строить самим — в первую очередь зависит от наличия людей, способных вести разработку программного обеспечения. Если в моей организации таких людей нет, то мне ничего не остается, как решиться на покупку. Но, даже если такие люди найдутся, перед нами может встать необходимость решить, какие именно разработки им поручить.
Вообще говоря, если можно приобрести стандартный пакет, который сможет работать на моей системе, следует его купить. Это может сэкономить скудные, быстро становящиеся еще более скудными ресурсы разработчиков программного обеспечения. И, несмотря на большие затраты на аппаратуру, такое решение обычно оказывается приемлемым.
Стандартный пакет имеет и свои достоинства, и свои недостатки. (См. табл. 6.23.) Но, невзирая на некоторые минусы, при малейшем шансе на успех мы должны использовать стандартное обеспечение.
Таблица 6.23 «3а» и «против» стандартных пакетов
Преимущества | Недостатки |
---|---|
Доступен сразу же | Универсален и, значит, не очень точно подходит |
Модифицируется и исправляется поставщиком | Тратит некоторые ресурсы ЦП |
Позволяет использовать разработчиков программного обеспечения на других работах | Не точно соответствует данной прикладной области |
Зависит от некоторой посторонней организации |
Если программное обеспечение нужно разрабатывать, должны ли мы делать это сами или можно заказать его на стороне? Посмотрите на табл. 6.4 — в ней перечислены все «за» и «против».
Таблица 6.4. Разрабатывать программное обеспечение самому или заказывать на стороне?
Разработка внутри | Заказ на стороне | ||
---|---|---|---|
Улучшается контроль | Требует значительных людских ресурсов | Сохраняются людские ресурсы | Затрудняется процесс сопровождения |
Уменьшается стоимость | Разработку ведут более квалифицированные и опытные специалисты | ||
Создается готовая группа сопровождения | Затрудняется процесс сопровождения |
Прежде всего необходимо
Здесь вам может потребоваться знакомство с руководителем программирования — причем самого высокого ранга, — который будет полностью отвечать за программирование. От него полностью зависит ваш успех или неудача.