Статический анализ программы - Static program analysis

Разработка программного обеспечения
Активность ядер
Парадигмы и модели
Методологии и рамки
Вспомогательные дисциплины
Практики
Инструменты
Стандарты и свод знаний
Глоссарии
Контуры

Статический анализ программы это анализ компьютерного программного обеспечения который выполняется без фактического выполнения программ, в отличие от динамический анализ, который представляет собой анализ программ во время их выполнения.[1][2] В большинстве случаев анализ проводится на какой-либо версии исходный код, а в других случаях - некоторая форма объектный код.

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

Обоснование

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

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

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

  1. Медицинское программное обеспечение: Соединенные штаты Управление по контролю за продуктами и лекарствами (FDA) выявило использование статического анализа для медицинских устройств.[5]
  2. Ядерное программное обеспечение: в Великобритании Управление ядерного регулирования (ONR) рекомендует использовать статический анализ системы защиты реактора.[6]
  3. Авиационное программное обеспечение (в сочетании с динамический анализ )[7]

Исследование, проведенное VDC Research в 2012 году, показало, что 28,7% опрошенных инженеров по встроенному ПО в настоящее время используют инструменты статического анализа, а 39,7% планируют использовать их в течение 2 лет.[8]Исследование 2010 года показало, что 60% опрошенных разработчиков в европейских исследовательских проектах хотя бы использовали свои базовые встроенные статические анализаторы IDE. Однако только около 10% использовали дополнительный другой (и, возможно, более продвинутый) инструмент анализа.[9]

В индустрии безопасности приложений имя Статическое тестирование безопасности приложений (SAST) также используется. SAST является важной частью жизненного цикла разработки безопасности (SDL), такого как SDL, определенный Microsoft.[10] и обычная практика в компаниях-разработчиках программного обеспечения.[11]

Типы инструментов

OMG (Группа управления объектами ) опубликовал исследование о типах анализа программного обеспечения, необходимого для качество программного обеспечения измерение и оценка. В этом документе «Как создать отказоустойчивые, безопасные, эффективные и легко изменяемые ИТ-системы в соответствии с рекомендациями CISQ» описаны три уровня анализа программного обеспечения.[12]

Уровень единицы
Анализ, который выполняется в рамках конкретной программы или подпрограммы, без подключения к контексту этой программы.
Уровень технологии
Анализ, который учитывает взаимодействие между отдельными программами, чтобы получить более целостное и семантическое представление о программе в целом, чтобы найти проблемы и избежать очевидных ложных срабатываний. Например, можно статически проанализировать стек технологий Android, чтобы найти ошибки разрешений.[13]
Системный уровень
Анализ, который учитывает взаимодействие между единичными программами, но не ограничивается одной конкретной технологией или языком программирования.

Можно определить следующий уровень анализа программного обеспечения.

Миссия / Бизнес Уровень
Анализ, который учитывает условия, правила и процессы уровня бизнеса / миссии, которые реализованы в системе программного обеспечения для ее работы как части деятельности уровня предприятия или уровня программы / миссии. Эти элементы реализуются, не ограничиваясь одной конкретной технологией или языком программирования, и во многих случаях распределены по нескольким языкам, но статически извлекаются и анализируются для понимания системы для обеспечения выполнения миссии.

Формальные методы

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

Прямым сокращением до проблема остановки, можно доказать, что (для любого Тьюринг завершен язык), поиск всех возможных ошибок времени выполнения в произвольной программе (или, в более общем смысле, любого нарушения спецификации в конечном результате программы) является неразрешимый: не существует механического метода, который всегда мог бы правдиво ответить, может или не может произвольная программа проявлять ошибки времени выполнения. Этот результат датируется работами Церковь, Гёдель и Тьюринг в 1930-е гг. (см .: Проблема с остановкой и Теорема Райса ). Как и в случае со многими неразрешимыми вопросами, можно попытаться дать полезные приблизительные решения.

Некоторые методы реализации формального статического анализа включают:[14]

Статический анализ на основе данных

Статический анализ на основе данных использует большие объемы кода для вывода правил кодирования.[16][нужен лучший источник ] Например, можно использовать все пакеты Java с открытым исходным кодом на GitHub, чтобы изучить хорошую стратегию анализа. Для вывода правил можно использовать методы машинного обучения.[17] Например, было показано, что когда кто-то слишком сильно отклоняется в способе использования объектно-ориентированного API, это, скорее всего, является ошибкой.[18] Также можно извлечь уроки из большого количества прошлых исправлений и предупреждений.[16][нужен лучший источник ]

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

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

  1. ^ Wichmann, B.A .; Canning, A. A .; Clutterbuck, D. L .; Winsbarrow, L.A .; Ward, N.J .; Марш, Д. В. Р. (март 1995 г.). «Промышленный взгляд на статический анализ» (PDF). Журнал программной инженерии. 10 (2): 69–75. Дои:10.1049 / sej.1995.0010. Архивировано из оригинал (PDF) 27 сентября 2011 г.
  2. ^ Эгеле, Мануэль; Шольте, Теодур; Кирда, Энгин; Крюгель, Кристофер (2008-03-05). «Обзор методов и инструментов автоматизированного динамического анализа вредоносных программ». Опросы ACM Computing. 44 (2): 6:1–6:42. Дои:10.1145/2089125.2089126. ISSN  0360-0300.
  3. ^ «Цели качества программного обеспечения для исходного кода» В архиве 2015-06-04 на Wayback Machine (PDF). Материалы: Конференция по встроенным программным средствам и системам реального времени 2010 г., ERTS2010.org, Тулуза, Франция: Патрик Бриан, Мартин Броше, Тьерри Камбуа, Эммануэль Кутенто, Оливье Гетта, Даниэль Майнберте, Фредерик Мондо, Патрик Мюнье, Лоик Нури, Филипп Спозио, Фредерик Ритейло
  4. ^ Повышение безопасности программного обеспечения с помощью точного статического анализа и анализа времени выполнения В архиве 2011-06-05 на Wayback Machine (PDF), Бенджамин Лившиц, раздел 7.3 «Статические методы для обеспечения безопасности». Докторская диссертация в Стэнфорде, 2006 г.
  5. ^ FDA (08.09.2010). «Исследование безопасности программного обеспечения инфузионного насоса в FDA». Управление по контролю за продуктами и лекарствами. В архиве из оригинала от 01.09.2010. Получено 2010-09-09.
  6. ^ Компьютерные системы безопасности - техническое руководство по оценке программных аспектов цифровых компьютерных систем защиты, «Компьютерные системы безопасности» (PDF). Архивировано из оригинал (PDF) 4 января 2013 г.. Получено 15 мая, 2013.
  7. ^ Позиционный документ CAST-9. Соображения по оценке подходов к проектированию безопасности к Software Assurance В архиве 2013-10-06 на Wayback Machine // FAA, Certification Authorities Software Team (CAST), январь 2002 г .: «Проверка. Заявитель / разработчик должен указать комбинацию статического и динамического анализа и применить ее к программному обеспечению».
  8. ^ Исследование VDC (01.02.2012). «Автоматическое предотвращение дефектов для обеспечения качества встроенного программного обеспечения». VDC Research. В архиве из оригинала от 11.04.2012. Получено 2012-04-10.
  9. ^ Праузе, Кристиан Р., Рене Райнерс и Сильвия Денчева. «Эмпирическое исследование инструментальной поддержки в широко распределенных исследовательских проектах». Global Software Engineering (ICGSE), 5-я Международная конференция IEEE, 2010 г. IEEE, 2010 г. http://ieeexplore.ieee.org/ielx5/5581168/5581493/05581551.pdf
  10. ^ М. Ховард и С. Липнер. Жизненный цикл разработки безопасности: SDL: процесс разработки значительно более безопасного программного обеспечения. Microsoft Press, 2006 г. ISBN  978-0735622142
  11. ^ Ахим Д. Брукер и Уве Содан. Развертывание статического тестирования безопасности приложений в большом масштабе В архиве 2014-10-21 на Wayback Machine. В GI Sicherheit 2014. Lecture Notes in Informatics, 228, pages 91-101, GI, 2014.
  12. ^ «Архивная копия» (PDF). В архиве (PDF) из оригинала 28.12.2013. Получено 2013-10-18.CS1 maint: заархивированная копия как заголовок (связь)
  13. ^ Бартель, Александр; Кляйн, Жак; Монперрус, Мартин; Ле Траон, Ив (1 июня 2014 г.). «Статический анализ для извлечения проверок разрешений из крупномасштабной платформы: проблемы и решения для анализа Android». IEEE Transactions по разработке программного обеспечения. 40 (6): 617–632. arXiv:1408.3976. Дои:10.1109 / tse.2014.2322867. S2CID  6563188.
  14. ^ Виджей Д’Сильва; и другие. (2008). «Обзор автоматизированных методов формальной проверки программного обеспечения» (PDF). Сделки по CAD. В архиве (PDF) из оригинала от 04.03.2016. Получено 2015-05-11.
  15. ^ Джонс, Пол (2010-02-09). «Основанный на формальных методах подход к проверке программного обеспечения медицинского устройства». Проектирование встроенных систем. Архивировано из оригинал 10 июля 2011 г.. Получено 2010-09-09.
  16. ^ а б «Учиться на чужих ошибках: анализ кода на основе данных». www.slideshare.net.
  17. ^ О, Хакджу; Ян, Хонгсок; Йи, Квангкын (2015). «Изучение стратегии адаптации программного анализа с помощью байесовской оптимизации». Труды Международной конференции по объектно-ориентированному программированию, системам, языкам и приложениям 2015 ACM SIGPLAN - OOPSLA 2015. С. 572–588. Дои:10.1145/2814270.2814309. ISBN  9781450336895. S2CID  13940725.
  18. ^ Монперрус, Мартин; Мезини, Мира (2013). «Обнаружение отсутствующих вызовов методов как нарушений правила большинства». ACM Transactions по программной инженерии и методологии. 22 (1): 1–25. arXiv:1306.0762. Дои:10.1145/2430536.2430541. S2CID  1212778.

дальнейшее чтение

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