Программная археология - Software archaeology

Программная археология или же программная археология исследование плохо документированных или недокументированных устаревшее программное обеспечение реализации, как часть обслуживание программного обеспечения.[1][2] Археология программного обеспечения, названная по аналогии с археология,[3] включает разобрать механизм с целью понять, как это работает программных модулей, а также применения различных инструментов и процессов для извлечения и понимания структуры программы и восстановления проектной информации.[1][4] Археология программного обеспечения может выявить дисфункциональные командные процессы, в результате которых были созданы плохо спроектированные или даже неиспользуемые программные модули.[5] Этот термин использовался десятилетиями,[6] и отражает довольно естественную метафору: программист, читающий устаревший код может почувствовать, что он или она находится в той же ситуации, что и археолог, исследующий руины древней цивилизации.[7]

Методы

Семинар по археологии программного обеспечения в 2001 г. OOPSLA (Объектно-ориентированное программирование, системы, языки и приложения) на конференции были определены следующие методы археологии программного обеспечения, некоторые из которых специфичны для объектно-ориентированного программирования:[7]

В более общем смысле, Энди Хант и Дэйв Томас отметить важность управление версиями, управление зависимостями инструменты индексирования текста, такие как СЛУЧАЙНО ЗАМЕТИТЬ и SWISH-E и «[рисует] карту в начале исследования».[7]

Как и настоящая археология, программная археология включает в себя исследовательскую работу для понимания мыслительных процессов своих предшественников.[7] В мастерской OOPSLA, Уорд Каннингем предложил метод синоптического анализа сигнатур, который дает общее "ощущение" программы, показывая только знаки препинания, такие как точки с запятой и Фигурные скобки.[8] В том же духе Каннингем предложил просматривать программы с использованием двухточечного шрифта, чтобы понять общую структуру.[9] Еще одна техника, выявленная на семинаре, заключалась в использовании аспектно-ориентированное программирование инструменты, такие как AspectJ систематически вводить отслеживание код без прямого редактирования унаследованной программы.[7]

Методы сетевого и временного анализа могут выявить закономерности совместной деятельности разработчиков устаревшего программного обеспечения, что, в свою очередь, может пролить свет на сильные и слабые стороны создаваемых программных артефактов.[10]

Майкл Розлог из Embarcadero Technologies описал археологию программного обеспечения как шестиэтапный процесс, который позволяет программистам отвечать на такие вопросы, как «Что я только что унаследовал?» и «Где страшные участки кода?»[11] Эти шаги, аналогичные тем, которые были определены на семинаре OOPSLA, включают использование визуализации для получения визуального представления дизайна программы с использованием показатели программного обеспечения искать нарушения дизайна и стиля, используя модульное тестирование и профилирование для поиска ошибок и узких мест в производительности, а также для сбора проектной информации, восстановленной в процессе.[11] Археология программного обеспечения также может быть услугой, предоставляемой программистам внешними консультантами.[12]

Митч Розенберг из InfoVentions.net, Inc. утверждает[нужна цитата ] что первый закон археологии программного обеспечения (он называет это археологией кода или данных):

Все, что есть, существует по определенной причине, и есть 3 возможных причины:

  1. Раньше он должен был быть там, но больше не нужен
  2. Его никогда не было там, и человек, который написал код, понятия не имел
  3. Он ЕЩЕ должен быть там, и ВЫ не имеете ни малейшего понятия

Следствием этого «закона» является то, что, пока вы не узнаете, в чем причина, вы НЕ должны изменять код (или данные).

Археология программного обеспечения продолжает оставаться темой обсуждения на недавних конференциях по разработке программного обеспечения.[13]

Профессия программист-археолог занимает видное место в Вернор Виндж с Глубина в небе. [14]

Смотрите также

Рекомендации

  1. ^ а б Роблес, Грегорио; Гонсалес-Бараона, Хесус М .; Херрайс, Израиль (2005). «Эмпирический подход к археологии программного обеспечения» (PDF). Постерные материалы Международной конференции по сопровождению программного обеспечения.
  2. ^ Эмблер, Скотт В. «Agile Legacy System Analysis и интеграционное моделирование». agilemodeling.com. Получено 2010-08-20. Без точной документации или доступа к знающим людям ваше последнее средство может заключаться в анализе исходного кода унаследованной системы ... Это усилие часто называют археологией программного обеспечения.
  3. ^ Мойер, Брайон (4 марта 2009 г.). «Археология программного обеспечения: модернизация старых систем» (PDF). Журнал встроенных технологий.
  4. ^ Хопкинс, Ричард; Дженкинс, Кевин (2008). "5. Мифический Метаман". Eating the IT Elephant: переход от разработки с нуля к строительству с нуля. Эддисон-Уэсли. п. 93. ISBN  978-0-13-713012-2.
  5. ^ Спинеллис, Диомидис; Гусиос, Георгиос (2009). "2. Повесть о двух системах § Отсутствие сплоченности". Красивая архитектура. О'Рейли. п. 29. ISBN  978-0-596-51798-4.
  6. ^ Раннее обсуждение Грасс, Джудит Э. (зима 1992 г.). «Археология объектно-ориентированного дизайна с CIA ++» (PDF). Вычислительные системы. 5 (1).
  7. ^ а б c d е Хант, Энди; Томас, Дэйв (Март – апрель 2002 г.). «Археология программного обеспечения» (PDF). Программное обеспечение IEEE. 19 (2): 20–22. Дои:10.1109/52.991327.
  8. ^ Каннингем, Уорд (2001). «Опрос подписи: метод просмотра незнакомого кода». Заявление о позиции семинара, Археология программного обеспечения: понимание больших систем, OOPSLA 2001.
  9. ^ Кук, Джон Д. (10 ноября 2009 г.). «Археология программного обеспечения». Стремление.
  10. ^ де Соуза, Клейдсон; Froehlich, Джон; Dourish, Пол (2005). «В поисках источника: исходный код программного обеспечения как социальный и технический артефакт» (PDF). Материалы Международной конференции ACM SIGGROUP 2005 г. по поддержке групповой работы. С. 197–206. Дои:10.1145/1099203.1099239. ISBN  1595932232.
  11. ^ а б Розлог, Михаил (28 января 2008 г.). «Археология программного обеспечения: что это такое и почему разработчики Java должны волноваться?». java.sys-con.com.
  12. ^ Шарвуд, Саймон (3 ноября 2004 г.). "В поисках утраченного кода". ZDNet.
  13. ^ Например, "32-я Международная конференция ACM / IEEE по программной инженерии". Май 2010 г..
  14. ^ Рис, Гарет (12 июня 2013 г.). «Археология программного обеспечения и технический долг».

внешняя ссылка