Программное обеспечение принцип Питера - Software Peter principle
Эта статья включает Список ссылок, связанное чтение или внешняя ссылка, но его источники остаются неясными, потому что в нем отсутствует встроенные цитаты.Август 2011 г.) (Узнайте, как и когда удалить этот шаблон сообщения) ( |
Эта статья возможно содержит оригинальные исследования.Октябрь 2019) (Узнайте, как и когда удалить этот шаблон сообщения) ( |
В Программное обеспечение принцип Питера используется в программная инженерия описать умирающий проект, который стал слишком сложным для понимания даже его собственными разработчиками.
Это хорошо известно в отрасли[нужна цитата ] как тихий убийца проектов, но к моменту появления симптомов часто уже слишком поздно что-либо с этим делать[нужна цитата ]. Хорошие менеджеры могут избежать этой катастрофы, установив четкие методы кодирования, избегая излишне сложного кода и дизайна.
Имя используется в книге C ++ FAQs (см. ниже), и получается из Принцип Питера - теория о некомпетентности в иерархических организациях.
Причины
Утрата концептуальной целостности
Концептуальная целостность программного обеспечения - это мера того, насколько хорошо оно соответствует единому простому набору принципов проектирования, согласно Месяц мифического человека к Фред Брукс[нужна цитата ]. Когда все сделано правильно, он обеспечивает максимальную функциональность используя самый простой идиомы. Это упрощает использование программного обеспечения, упрощая его создание и изучение.[нужна цитата ].
Концептуальная целостность достигается, когда дизайн программного обеспечения исходит от небольшого числа согласных людей[нужна цитата ]. Чтобы программное обеспечение сохраняло концептуальную целостность, проект должен контролироваться одной небольшой группой людей, которые хорошо разбираются в коде (включая природу взаимодействия всех подпрограмм и переменных).
В проектах без сильного программная архитектура команда, задача дизайна часто сочетается с задачей реализации и неявно делегируется между отдельными разработчики программного обеспечения. В этих условиях разработчики менее склонны жертвовать личными интересами в пользу интересов продукта. Сложность продукта возрастает в результате того, что разработчики добавляют новые дизайны и изменяют предыдущие, чтобы отразить изменения в моде и индивидуальном вкусе.
Некомпетентность программиста
По мнению авторов, лучшие разработчики программного обеспечения понимают важность общения с людьми, а не общения с компьютером. Код завершен к Стив МакКоннелл. В среднем 85 процентов времени программиста тратится на общение с людьми, и только 15 процентов - на общение с компьютером.[нужна цитата ] Программисты обслуживания тратят от 50 до 60 процентов своего времени, пытаясь понять код, который они должны обслуживать, а программа будет иметь в среднем 10 поколений программистов обслуживания.
Неопытность программиста
Иногда программисты принимают решения, которые работают, но имеют непредвиденные негативные последствия. Наиболее частые из этих ошибок занесены в каталог и обозначены как пахнет в книге Рефакторинг к Мартин Фаулер. Со временем многие такие варианты реализации ухудшают дизайн программного обеспечения, делая его все более трудным для понимания.
Смотрите также
- Анти-паттерны
- Марш смерти (управление проектом)
- Десятое правило Гринспана
- Управление проектом
- Процесс разработки программного обеспечения
- Обфускация (программное обеспечение)
Рекомендации
- C ++ FAQs Клайн, Ломоу и Жиру, Addison-Wesley 1999 ISBN 0-201-30983-1
- Брукс, Ф., Мифический человеко-месяц, Addison-Wesley Longman Inc., 1995.
- Макконнелл, С., Код завершен, Microsoft Press, 1993 г.
- Фаулер, М., Рефакторинг, Эддисон-Уэсли, 2000 г.