|
Поиск семантических ошибок, возникающих при некорректной адаптации скопированных участков кода
Севак Саргсян Институт системного программирования РАН
Аннотация:
В статье предлагается новый метод поиска семантических ошибок, возникающих при неправильном копировании исходного кода в процессе разработки ПО. Метод состоит из двух основных этапов. На первом этапе производится поиск клонов кода на основе лексического анализа программы. Найденные идентичные последовательности лексем фильтруются путем частичного разбора. После чего в них остаются целостные конструкции, допускаемые языком программирования. На втором этапе производится анализ найденных клонов с целью обнаружения допущенных ошибок при копировании. Для этого строится и анализируется граф зависимостей программы (Program Dependence Graph — PDG). Предложенный подход реализован в компиляторной инфраструктуре LLVM/Clang, что позволяет эффективным образом производить анализ, во время компиляции проекта. Найденные ошибки выдаются в виде предупреждений для разработчика. В статье приводится результаты анализа ядра Linux 2.6 и Android 4.3. Инструмент обеспечивает точность выше 65%.
Ключевые слова:
семантический анализ, семантические ошибки, поиск клонов, PDG, LLVM.
Образец цитирования:
Севак Саргсян, “Поиск семантических ошибок, возникающих при некорректной адаптации скопированных участков кода”, Труды ИСП РАН, 27:2 (2015), 93–104
Образцы ссылок на эту страницу:
https://www.mathnet.ru/rus/tisp124 https://www.mathnet.ru/rus/tisp/v27/i2/p93
|
|