Jump to content

Наступательное программирование

Наступательное программирование — это название, используемое для отрасли защитного программирования , которая явно отходит от защитных принципов при работе с ошибками, возникающими в результате ошибок программного обеспечения . Хотя это название является реакцией на крайние интерпретации защитных программ, они не противоречат фундаментально. Скорее, наступательное программирование добавляет явный приоритет недопустимости ошибок в неправильных местах: точка, в которой оно отходит от крайних интерпретаций защитного программирования, заключается в предпочтении наличия ошибок внутри линии защиты программы явно очевидным гипотетическим преимуществам безопасности. терпеть их. [1] [2] Это предпочтение также оправдывает использование утверждений .

Отличительные ошибки

[ редактировать ]

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

Контрастные примеры:

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

Стратегии обнаружения ошибок

[ редактировать ]

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

Стратегии:

  • Никаких ненужных проверок: основным принципом является уверенность в том, что другие программные компоненты ведут себя так, как указано, чтобы не скрыть любую неизвестную проблему. В частности, некоторые ошибки уже могут гарантированно привести к сбою программы (в зависимости от языка программирования или среды выполнения), например, разыменование нулевого указателя . Таким образом, проверки нулевого указателя не нужны для остановки программы (но их можно использовать для вывода сообщений об ошибках).
  • Утверждения — проверки, которые можно отключить — являются предпочтительным способом проверки вещей, в проверке которых нет необходимости, например, контрактов на проектирование между программными компонентами.
  • Удалить резервный код ( limp mode ) и резервные данные ( значения по умолчанию ). Они могут скрыть дефекты в основной реализации или, с точки зрения пользователя, скрыть тот факт, что программное обеспечение работает неоптимально. Особое внимание к нереализованным частям может потребоваться в рамках заводских приемочных испытаний , поскольку еще нереализованный код не находится на какой-либо стадии разработки через тестирование, которую можно было бы обнаружить при неудачных модульных тестах .
  • Удалите сокращенный код (см. шаблон стратегии ). Упрощенный путь к коду может скрыть ошибки в более общем пути к коду, если общий код почти никогда не запускается. Поскольку предполагается, что оба метода дают один и тот же результат, упрощенный вариант можно исключить.

См. также

[ редактировать ]
  1. ^ «Наступательное программирование» . Каннингем энд Каннингем, Инк . Проверено 4 сентября 2016 г.
  2. ^ Бродволл, Йоханнес (25 сентября 2013 г.). «Наступательное программирование» . Мышление внутри большей коробки . Проверено 4 сентября 2016 г.
Arc.Ask3.Ru: конец переведенного документа.
Arc.Ask3.Ru
Номер скриншота №: 829b05a803a5bb545f903c48a700576e__1702722300
URL1:https://arc.ask3.ru/arc/aa/82/6e/829b05a803a5bb545f903c48a700576e.html
Заголовок, (Title) документа по адресу, URL1:
Offensive programming - Wikipedia
Данный printscreen веб страницы (снимок веб страницы, скриншот веб страницы), визуально-программная копия документа расположенного по адресу URL1 и сохраненная в файл, имеет: квалифицированную, усовершенствованную (подтверждены: метки времени, валидность сертификата), открепленную ЭЦП (приложена к данному файлу), что может быть использовано для подтверждения содержания и факта существования документа в этот момент времени. Права на данный скриншот принадлежат администрации Ask3.ru, использование в качестве доказательства только с письменного разрешения правообладателя скриншота. Администрация Ask3.ru не несет ответственности за информацию размещенную на данном скриншоте. Права на прочие зарегистрированные элементы любого права, изображенные на снимках принадлежат их владельцам. Качество перевода предоставляется как есть. Любые претензии, иски не могут быть предъявлены. Если вы не согласны с любым пунктом перечисленным выше, вы не можете использовать данный сайт и информация размещенную на нем (сайте/странице), немедленно покиньте данный сайт. В случае нарушения любого пункта перечисленного выше, штраф 55! (Пятьдесят пять факториал, Денежную единицу (имеющую самостоятельную стоимость) можете выбрать самостоятельно, выплаичвается товарами в течение 7 дней с момента нарушения.)