Научная статья на тему 'Разработка приложения для получения метрик программного продукта на языке объектно-ориентированного программирования'

Разработка приложения для получения метрик программного продукта на языке объектно-ориентированного программирования Текст научной статьи по специальности «Компьютерные и информационные науки»

CC BY
98
7
i Надоели баннеры? Вы всегда можете отключить рекламу.
Ключевые слова
метрика / язык объектно-ориентированного программирования / статический анализ кода / оценка программного продукта / metrics / object-oriented programming language / static code analysis / software product evaluation

Аннотация научной статьи по компьютерным и информационным наукам, автор научной работы — Артем Олегович Корзников, Наталья Николаевна Дацун

Все группы процессов жизненного цикла программного продукта на стороне разработ-чика сложны в осуществлении. При этом следует учитывать возможность генерации программного кода, а в случае командной работы – потребность оценки вклада каждого ее участника. В работе предлагается количественная оценка различных аспектов программного обеспечения путем вычис-ления метрик программного кода. Цель данной работы – разработка приложения расчета метрик для различных языков объектно-ориентированного программирования (ООП). Задачами являются разработка подходов к применению метрик для оценки и сравнения программного кода, реализация приложения расчета метрик. Создано описание для подмножества языков C#, C++ и Java. Впервые предложены шкалы значений для метрик Холстеда, подходы к анализу динамики изменения про-граммного продукта и сравнению различных программ решения одной задачи. Это позволяет дать интерпретацию значений метрик. Разработано приложение Metrics Observer расчета 11 метрик для программ на языке ООП и 16 метрик, не зависящих от парадигмы. Практическая значимость состоит в подготовке решений для сравнения различных реализаций одной задачи, выявления участков кода для рефакторинга, оценки динамики изменения качества кода в процессе разработки / рефакторинга и вклада в проект отдельных разработчиков

i Надоели баннеры? Вы всегда можете отключить рекламу.
iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.
i Надоели баннеры? Вы всегда можете отключить рекламу.

Program Realization for Code Metrics Calculation in Object-Oriented Programming Language

All groups of software product lifecycle processes executed by developers are complicated to implement. The code generation possibility and a requirement of evaluation for each participant contri-bution in case of teamwork also should be considered. A quantitative estimation for various aspects of software is proposed by code metrics calculation. The work purpose is development of a program for calculating the metrics of a software product for various object-oriented programming languages. The tasks are development of metrics exploitation approaches for evaluating and comparing code and imple-mentation of the metric calculation program. The description for subsets of the languages C#, C++ and Java was created. A values gradation Halstead metrics and the approaches for analyzing dynamic changes of a software product and comparison of different programs solving the same problem are pro-posed and first allowed calculated metrics values interpretation. “Metrics Observer” program was devel-oped. It calculates 11 metrics values for programs in object-oriented language and 16 metrics values that do not depend on the paradigm. Practical significance is to prepare solutions for comparing different implementations of the same task, identifying code modules for refactoring, estimating dynamic code quality changes during the development / refactoring process and individual contributions of developers to a project.

Текст научной работы на тему «Разработка приложения для получения метрик программного продукта на языке объектно-ориентированного программирования»

2023

ВЕСТНИК ПЕРМСКОГО УНИВЕРСИТЕТА

• Математика. Механика. Информатика • Вып. 3(62)

«Информатика, кибернетика и вычислительная техника»

Научная статья УДК 004.412

DOI: 10.17072/1993-0550-2023-3-76-84

Разработка приложения для получения метрик

программного продукта на языке объектно-ориентированного программирования

Артем Олегович Корзников1, Наталья Николаевна Дацун2

1 2Пермский государственный национальный исследовательский университет, Пермь, Россия 1artemkorz@mail.ru, https://orcid.org/0009-0006-3941-9214 2nndatsun@inbox.ru, https://orcid.org/0000-0001-8560-7036

Аннотация. Все группы процессов жизненного цикла программного продукта на стороне разработчика сложны в осуществлении. При этом следует учитывать возможность генерации программного кода, а в случае командной работы - потребность оценки вклада каждого ее участника. В работе предлагается количественная оценка различных аспектов программного обеспечения путем вычисления метрик программного кода. Цель данной работы - разработка приложения расчета метрик для различных языков объектно-ориентированного программирования (ООП). Задачами являются разработка подходов к применению метрик для оценки и сравнения программного кода, реализация приложения расчета метрик. Создано описание для подмножества языков C#, C++ и Java. Впервые предложены шкалы значений для метрик Холстеда, подходы к анализу динамики изменения программного продукта и сравнению различных программ решения одной задачи. Это позволяет дать интерпретацию значений метрик. Разработано приложение Metrics Observer расчета 11 метрик для программ на языке ООП и 16 метрик, не зависящих от парадигмы. Практическая значимость состоит в подготовке решений для сравнения различных реализаций одной задачи, выявления участков кода для рефакторинга, оценки динамики изменения качества кода в процессе разработки / рефакторинга и вклада в проект отдельных разработчиков.

Ключевые слова: метрика; язык объектно-ориентированного программирования; статический анализ кода; оценка программного продукта

Для цитирования: Корзников А.О., Дацун Н.Н. Разработка приложения для получения метрик программного продукта на языке объектно-ориентированного программирования // Вестник Пермского университета. Математика. Механика. Информатика. 2023. Вып. 3(62). С. 76-84. DOI: 10.17072/1993-0550-2023-3-76-84.

Статья поступила в редакцию 05.07.2023; одобрена после рецензирования 31.07.2023; принята к публикации 15.09.2023.

«Computer Science, Cybernetics and Computing» Research article

Program Realization for Code Metrics Calculation in Object-Oriented Programming Language

Artem O. Korznikov1, Natalya N. Datsun2

1,2Perm State University, Perm, Russia 1artemkorz@mail.ru, https://orcid.org/0009-0006-3941-9214 2nndatsun@inbox.ru, https://orcid.org/0000-0001-8560-7036

Эта работа О 2023 Корзников А.О., Дацун H.H. под лицензией СС BY 4.0. Чтобы просмотреть копию этой лицензии, посетите http://creativecommons.Org/licenses/by/4.0/

Abstract. All groups of software product lifecycle processes executed by developers are complicated to implement. The code generation possibility and a requirement of evaluation for each participant contribution in case of teamwork also should be considered. A quantitative estimation for various aspects of software is proposed by code metrics calculation. The work purpose is development of a program for calculating the metrics of a software product for various object-oriented programming languages. The tasks are development of metrics exploitation approaches for evaluating and comparing code and implementation of the metric calculation program. The description for subsets of the languages C#, C++ and Java was created. A values gradation Halstead metrics and the approaches for analyzing dynamic changes of a software product and comparison of different programs solving the same problem are proposed and first allowed calculated metrics values interpretation. "Metrics Observer" program was developed. It calculates 11 metrics values for programs in object-oriented language and 16 metrics values that do not depend on the paradigm. Practical significance is to prepare solutions for comparing different implementations of the same task, identifying code modules for refactoring, estimating dynamic code quality changes during the development / refactoring process and individual contributions of developers to a project.

Keywords: metrics; object-oriented programming language; static code analysis; software product evaluation

For citation: Korznikov A.O., Datsun N.N. Program Realization for Code Metrics Calculation in Object-Oriented

Programming Language. Bulletin of Perm University. Mathematics. Mechanics. Computer Science.

2023;3(62):76-84. (In Russ.). DOI: 10.17072/1993-0550-2023-3-76-84.

The article was submitted 05.07.2023; approved after reviewing 31.07.2023; accepted for publication 15.09.2023.

Введение

При постоянном совершенствования и обновлении информационных технологий (ИТ) - цифровая экономика, решения на основе искусственного интеллекта, всепроникающие ИТ и т. д. - зачастую затруднительно корректно определить экономические характеристики проекта. В настоящее время метрики широко применяются в программной инженерии [1] при оценивании труда программистов: объема, качества и сложности проделанной работы на различных этапах жизненного цикла программного продукта. Кроме того, отраслевые стандарты, такие как ISO 9000 [2] и модели, например, CMM [3] и CMMI [4], также включают работу с метриками.

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

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

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

В табл. 1 приведено сравнение систем для расчета метрик c разработанным приложением Metrics Observer.

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

В данной работе реализовано приложение Metrics Observer, не зависящее от описания конкретного языка. В используемый набор метрик [9] входят стандартные метрики (строки кода, оценка стилистики), метрики Холстеда, а также метрики кода объектно-ориентированных программ: метрики Чидамбера и Кемерера, метрики Лоренца и Кидда. Разработано описание языка объектно-ориентированного программирования (ООП) при помощи двух файлов. Составлено описание для подмножества языков C#, C++ и Java. Приведены примеры использования приложения.

1. Анализ языков ООП

Различные языки программирования отличаются лексикой, синтаксисом и семантикой.

Набор лексем можно условно разделить на операнды и операторы: ключевые слова и специальные символы.

Для различных языков их состав не идентичен, причем одни и те же элементы лексики в некоторых из них могут являться,

например, операторами, в иных - операндами, а также это может зависеть от контекста в рамках одного языка. Исходя из этого, необходимо четкое задание списка зарезервированных слов языка еще на этапе лексического анализа для его корректного осуществления. В этом разделе обсуждаются объектно-ориентированные языки C#, Java, C++ и Python. На рис. 1 показано сравнение состава лексем для них.

Таблица 1. Сравнение систем для расчета метрик программных продуктов

Название системы, источник Язык анализируемых программ Количество метрик, расчет которых реализован в системе

Стандартные метрики Метрики ООП Метрики потока управления Метрики стилистики

MS Visual Studio [6] C# 2 2 1 1

Source Stat [7] C, C++ 2 0 0 1

NLOC [8] C, C++, C#, Java, Visual Basic, Pascal, Delphi 2 0 0 1

Metrics [10] C# 16 11 0 1

Metrics Observer C#, C++, Java 16 11 0 1

Таблица 2. Сравнение синтаксических конструкций объектно-ориентированных языков

Рис. 1. Обобщение и специализация ключевых слов и зарезервированных символов языков ООП

Ввиду принадлежности рассматриваемых языков к одной парадигме программирования, состав синтаксических конструкций языка является схожим. Однако каждый язык имеет собственные особенности их описания.

В табл. 2 приведено описание некоторых из структурных единиц языков ООП. Так, в С# возможно отдельное описание свойств в качестве элементов класса, в то время как в остальных языках допускается лишь создание соответствующих методов. В то же время, по сравнению с С#, языки обладают более сложным синтаксисом. Например, С++ допускает множественное наследование, обладает более сложным описанием связи дочернего и родительского класса.

Язык ООП Реализация наследования

C# <заголовок класса> : := class <имя> [":" <имя базового класса>]

C++ <заголовок класса> ::= class <имя> [":" [<модификаторы>] <имя базового класса> ("," <имя базового класса>)]

Python <заголовок класса> ::= class <имя> ["(" <имя базового класса> ("," <имя базового класса>) ")"]

Помимо этого, в одной и той же синтаксической структуре могут присутствовать разные лексемы, которые имеют идентичное предназначение (например, символ ":" и ключевое слово "extends" в различных языках обозначают, что далее будет записан базовый класс при описании наследования). Кроме того, некоторые из лексем могут быть парными, такие как открывающие и закрывающие скобки.

Существуют и другие отличия семантики объектно-ориентированных языков, оказывающие влияние на интерпретацию кода. В том числе, для корректного определения теку-

щего элемента программы необходимо учитывать семантику конструкторов, имеющих имя, совпадающее с именем класса. Необходимо корректно распознавать и общие для всех языков программирования элементы, например, выражения, операторы, идентификаторы. Также для вычисления значений метрик ООП необходимо определять такие общие элементы, как пространства имен, классы и блоки кода, находить и запоминать некоторые их характеристики. Помимо этого, семантика оказывает влияние и на расчет промежуточных значений метрик, например, полное имя записывается с помощью названий пространств имен и классов (объектов).

2. Обобщенное определение синтаксиса языков ООП

Для извлечения определенных конструкций языка, необходимых при вычислении значений набора метрик, составлено формальное описание. Исходя из поставленной задачи, проверяемая программа предполагается компилируемой, задачей структур описания языка является их выделение из кода для последующего анализа. Синтаксис определен при помощи форм Бэкуса-Наура для универсального задания для трех объектно-ориентированных языков: C#, Java и C++. Фрагмент набора БНФ представлен на рис. 2.

<программа> ::= {-оператор добавления ресурса> } < элемент программы> { < элемент ирограммы> }

<оператор добавления ресурса> ::= <initExtemalSyKw> <оператор добавления ресурса CS> | <оператор добавления ресурса JAVA> | <оператор добавления ресурса СРР>

<оператор добавления ресурса CS :: <выражение> ^оператор добавления ресурса JAVA> <модификаторы> <выражение>

<оператор добавления ресурса СРР> " <имя> ">"

<константа> | namespace <имя> м;"

< элемент программы - ::= <пространство иыен> | <класс> | <перечисление> | -метод>

Рис. 2. Пример БНФ

3. Описание лексики и связанной семантики языка

Описание лексики языка формируется при помощи json-файла по определенным правилам. Было построено описание для подмножеств объектно-ориентированных языков программирования: C# 7.3, Java SE 8, C++ 11.

Описание лексики языка включает определение ключевых слов и специальных символов языка. К ключевым словам ("Keywords") отнесены лексемы, являющиеся зарезервированными. К лексемам специальных символов ("Symbols") отнесены любые лексемы, не содержащие буквы алфавита кириллицы и латиницы, арабские цифры.

К семантике, связанной с лексикой, относится разделение лексем на группы ("Groups") в соответствии с выполняемой задачей в коде и задание пар лексем ("Pairs"). Для определения группы необходимо указать название ("Name") и список значений, вошедших в ее состав ("Values"). Пары лексем определяются при помощи двух значений лексем ("Name" и "Linked"). Также файл лексики хранит дополнительную информацию о языке: список расширений файлов кода программ, ("Extensions"), список расширений файлов, которые необходимо исключить при поиске файлов языка ("Except") и имя файла синтаксиса языка ("Syntax"). Общий вид файла можно увидеть на рис. 3.

Рис. 3. Общий вид файла описания лексики

4. Структуры данных описания кода

Для расчета отобранных метрик необходимо определить значения, участвующие в вычислениях. Они представлены в четырех классах, описывающих код анализируемых программ.

Класс "Блок кода" - базовая структурная единица описания кода программы на объектно-ориентированном языке, которая содержит: название структуры, список полей, список методов, словарь лексем. Кроме того, класс обладает методом для слияния словарей лексем.

Класс "Элемент описания кода", являющийся наследником класса "Блок кода", хранит списки полей и методов. Помимо этого, класс обладает дополнительными атрибутами, которые представляют: список блоков кода, текущий уровень в иерархии классов, список дочерних классов, количество переопределяемых

подклассом методов, количество конструкторов. Кроме того, класс включает список блоков кода и классов, являющихся непосредственными потомками, что позволяет произвести расчет метрик для программ языков ООП.

"Корневой класс" отличается от предыдущего элемента описания отсутствием родительского класса при моделировании иерархии наследования. Данный класс сохраняет характеристики класса "Элемент описания кода", дополняя их глубиной дерева наследования, отвечает за получение значения данной метрики.

"Пространство имен" - элемент описания кода, который может хранить классы. Наследует от класса поля, хранящие элементы структур. Содержит списки: подпространств имен и классов. Данный класс выполняет преобразование списка классов в их древовидные структуры, соответствующие иерархии наследования, сохраняя на верхнем уровне корневые классы.

В результате описание анализируемой программы образует дерево. Корнем является пространство имен проекта, содержащее пространства имен и их подпространства. Узлы этого уровня включают в себя корневые классы, содержащие дочерние классы. Листья являются блоками кода.

5. Описание синтаксиса языка и связанной семантики

Файл хт1-формата использован для определения синтаксиса и необходимой для расчета отобранного набора метрик семантики языка.

Для задания правил построения описания составлены БНФ, пример которых представлен на рис. 4. Также этот файл задает логику для расчета промежуточных значений метрик.

<описание> ::=<xmlver> <ArrayQ£Element>

<ArrayQ£Elcment> ::= <arrayTag> <Program> {<Element>} <array T a gC la s e>

<Program> : := <ElementTag> <NameTag> "program" <NameTaeClose> <Descriptrioii> <ElemeiitTaeClose>

<Element> : := <ElcmcntTag> <NameValue> <Variable&> <Descriptrion> <Retimi> <ELementTagCLose>

<Descriptrion> : := <DescriptrionTag> ¡<Entity>} <DescriptrionTagClose>

<Entity> :: = <EntityTag> (<Condition> <Inshnction> <Reserved> <ProgramElement>) <EntityTagClcise>

6. Алгоритм работы приложения

Алгоритм работы приложения (рис. 5) включает нахождение файлов проекта, подлежащих анализу, описания соответствующих языков программирования, статический анализ кода [11] анализируемого приложения и расчет метрик по результатам анализа.

Рис. 4. БНФ описания файла описания синтаксиса

Рис. 5. Алгоритм работы приложения

7. Анализ программного продукта по значениям метрик

На рис. 6 представлены вычисленные метрики проекта Metrics Observer.

Комментарий к полученным результатам приведен на рис. 7. Он составлен для метрик, значения которых можно сравнить с определенной теоретической нормой.

Значение метрики "Оценка количества комментариев" является отрицательным, поэтому программу можно считать не задокументированной.

Рис. 6. Вычисленные значения метрик для проекта Metrics Observer

Стандартные метрики Метрики Холстеда

Дипл nporpa^-to С поале». программ

И Программа тл^ок^мелгцхлаи

iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.

Оптимальна положительное

|l8D9i блтзка к по***

"top оце<-ка Т4532.9 |isia

И Е

Твор. оц«а: Т2041Ш

Метрики Чидамбера и Кенерера

Неооста так связности в метода*

Метрики Лоренца и Кидда

|Рмм«р класса

Метоям програ»»»>1 достато*« станы

Оптимально: Слизкое к 0

|7.Я Г^ограмма соответствуй норме.

Оптимально: не Солее 20 |0.Ю2

Олимлльно: не Сол«» 3

[Высота дерева наследования

: е

До&мпммые подкпаоооы операции

Оптимально: не более? Оптимально: не Солее 4

Рис. 7. Комментарий к вычисленным значениям

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

Существует недостаток связности в методах, но он лежит в пределах допустимого, поэтому методы программы достаточно связаны. Все рассматриваемые метрики Лоренца и Кидда соответствуют оптимальным значениям, поэтому программа соответствует норме, установленной для данной группы метрик.

8. Анализ динамики изменения программного продукта

Для анализа использовались различные версии одного приложения. Для каждой версии были определены значения метрик и максимальные значения из полученных для всех рассматриваемых версий, которые указаны в табл. 3. Определена доля каждого значения метрики от максимального, и проведено сравнение с помощью диаграммы (рис. 8).

Количество логических строк кода отражает размер программы. Рост показателей метрик "Оценка уровня качества программирования" и "Индекс специализации" является желательным, "Сложность" и "Верхняя оценка количества ошибок" - нежелательным.

Таблица 3. Вычисленные метрики для различных версий программного продукта

Метрика Версия программного продукта

№1 №2 №3 №4

Логические строки кода 12706 13492 13162 13633

Оценка уровня качества программирования 0.553 0.555 0.548 0.559

Сложность 245.9 249.8 241.2 243.8

Верхняя оценка количества ошибок 138.5 145.6 144.6 140.7

Сцепление между классами 8.84 7.57 7.43 7.43

Отклик класса 35.3 33.8 34 33.5

Недостаток связности в методах 191.3 117.8 87.6 81.5

Индекс специализации 0.179 0.425 0.425 0.425

Для значений других метрик необходимо некоторое оптимальное значение.

Метрики "Сцепление между классами", "Отклик класса", "Недостаток связности в методах" и "Индекс специализации" относятся к метрикам ООП.

Метрика "Индекс специализации" связана с иерархией наследования.

Рис. 8. Изменение значений метрик в зависимости от версии приложения

Анализ полученных значений метрик показал, что на протяжении изменений в версиях 1-4 снижаются значения метрик "Сцепление между классами" и "Недостаток связности в методах".

В результате внесения изменений между версиями 1 и 2 повысилось значение метрик "Индекс специализации", "Верхняя оценка количества ошибок" и "Сложность",

После внесения изменений возросли значения метрик "Логические строки кода", "Оценка уровня качества программирования", "Верхняя оценка количества ошибок" по отношению к изначальным и понизилось значение "Сложность".

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

9. Анализ программного продукта на основании средних значений метрик

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

ческое (табл. 4). Определена доля каждого значения метрики от среднего значения для сравнения с помощью диаграммы (рис. 9).

У анализируемой программы Г показатели метрик "Объем программы", "Сложность", "Верхнее время программирования", рост которых не желателен, ниже средних для аналогичных программ. При этом высота дерева наследования не отличается от средней, однако, ниже число добавляемых подклассом операций, индекс специализации существенно отличается.

Таблица 4. Вычисленные метрики для различных версий программного продукта

Метрика Программный продукт Среднее Прог. Г

А Б В

Объем программы 730 644 719 698 322

Верхнее время программирования 0.27 0.25 0.28 0.27 0.073

Сложность 14.9 15.8 15.4 15.36 11.9

Высота дерева наследования 2 2 2 2 2

Добавляемые подклассом операции 1 2 1 1.33 1

Индекс специализации 0.5 0.33 0.5 0.44 0

Рис. 9. Сравнение со средним значением для программы Г

На основании наблюдений можно сделать вывод: приложение Г является более простым для понимания и реализации, в то же время, классы в иерархии наследования сильно

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

Заключение

Проанализированы современные языки объектно-ориентированного программирования и составлен набор метрик для комплексного анализа свойств программного продукта на этих языках. Выполнен анализ доступных приложений для расчета метрик.

Определен обобщенный синтаксис подмножеств объектно-ориентированных языков C#, C++ и Java с помощью БНФ. Разработано описание языка объектно-ориентированного программирования при помощи файлов описания лексики и синтаксиса и связанной с ними семантики языка, необходимой для расчета метрик. Структура файла описания синтаксиса задана при помощи БНФ. Приложение Metrics Observer спроектировано независимо от описания конкретного языка из рассматриваемых.

Реализация выполнена на языке C#. Создано 67 классов. Описание поддерживаемых языков включает 4 файла: 3 json-файла описания лексики и 1 xml-файл описания синтаксиса. Разработка приложения выполнена в среде Microsoft Visual Studio 2019. Размер файла приложения: 121 КБ.

Приложение Metrics Observer позволяет вычислить 11 метрик ООП и 16 метрик, не зависящих от парадигмы. Тестирование проведено для программного кода проекта Metrics Observer (язык C#) и примеров программ на языках C++ и Java на трех испытательных стендах.

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

Кроме того, возможно создание приложения для интерпретации вычисленных значений метрик в зависимости от потребности пользователя.

Список источников

1. Xenos M. Software Metrics and Measurements // Encyclopedia of E-Commerce, E-Govern-ment and Mobile Commerce. Idea Group Publishing, 2006. P.1029-1036.

2. ISO 9000 family. Quality management. URL: https://www.iso.org/iso-9001-quality-manage-ment.html (дата обращения: 30.06.2023).

3. CMM. Capability Maturity Model. URL: https://www.geeksforgeeks.org/software-engi-neering-capability-maturity-model-cmm/ (дата обращения: 30.06.2023)

4. CMMI. Capability Maturity Model Integra-tion. URL: https://docs.microsoft.com/en-us/azure/-devops/boards/work-items/guidance/cmmi/-guidance-background-to -cmmi ?view=azure -devops (дата обращения: 30.06.2023).

5. Звездин С. Метрики как средство управления качеством // Открытые системы. СУБД. 2009. № 08. C. 36-40.

6. Значения метрик кода - Visual Studio (Windows). URL: https://docs.microsoft. com/ru-ru/visualstudio/code-quality/code-metrics-val-ues?view=vs-2019 (дата обращения: 30.06.2023).

7. SourceStat - расчет метрик программного обеспечения. URL: http://bitaks.com/products/sourcestat/sourcest at.html (дата обращения: 30.06.2023).

8. NLOC - Source Line Counter Tool. URL: http://nloc.sourceforge.net/index.html (дата обращения: 30.06.2023).

9. Lee M.-C., Chang T. Software Measurement

and Software Metrics in Software Quality // International Journal of Software Engineering and Its Applications. 2013. Vol. 7, № 4. P. 1534. URL: https://www.researchgate.net/publi-cation/260480820_Software_measure-ment_and_software_metrics_in_soft-ware_quality (дата обращения: 30.06.2023).

10. Корзников А.О., Дацун Н.Н. Реализация приложения расчета метрик кода на объектно-ориентированном языке программирования / Актуальные проблемы математики, механики и информатики: сб. статей по материалам студ. конф. / Перм. гос. нац. исслед. ун-т. Пермь, 2022. С. 40-45. URL: https://www.elibrary.ru/item.asp?id=49889579 (дата обращения: 30.06.2023).

11. Ахо А., Сети Р., Ульман Д. Компиляторы: Принципы, технологии, инструменты. М.: Вильямс, 2008. 1184 с.

References

1. Xenos M. Software Metrics and Measurements. Encyclopedia of E-Commerce, E-Gov-ernment and Mobile Commerce. Idea Group Publishing, 2006:1029-1036.

2. ISO 9000 family. Quality management. URL: https: //www .iso.org/iso -9001 -quality-man-agement.htm.

3. CMM. Capability Maturity Model. URL: https://www.geeksforgeeks.org/software-en-gineering-capability-maturity-model-cmm/.

4. CMMI. Capability Maturity Model Integration. URL: https://docs.microsoft.com/en-us/azure/devops/boards/work-items/guid-ance/cmmi/guidance-background-to-

cmmi ?view=azure -devops.

5. Zvezdin S. Metrics as means of quality manage-

ment. Open systems. DBMS. 2009;(08).36-40. (In Russ.).

6. Znacheniya metrik koda - Visual Studio (Win-

dows). URL: https://docs.microsoft.com/ru-ru/visualstudio/code-quality/code-metrics-values?view=vs-2019. (In Russ.). 7. SourceStat - raschet metrik programmnogo obespecheniya. URL: http://bitaks.com/prod-ucts/sourcestat/sourcestat.html. (In Russ.).

8. NLOC - Source Line Counter Tool. URL: http://nloc.sourceforge.net/index.html.

9. Lee M.-C., Chang T. Software Measurement and Software Metrics in Software Quality. International Journal of Software Engineering and Its Applications. 2013;7(4):15-34. URL: https://www.researchgate.net/publication /260480820_Software_measurement_and _software_metrics_in_software_quality.

10. Korznikov A.O., Datsun N.N. Realizaciya prilozheniya rascheta metrik koda na ob"ektno-orientirovannom yazyke program-mirovaniya / Aktual'nye problemy ma-tematiki, mekhaniki i informatiki: sb. statej po materialam stud. konf. / Perm. gos. nacion-al'nyj issledovatel'skij un-t. Perm', 2022:4045. URL: https://www.eli-brary.ru/item.asp?id=49889579. (In Russ.).

11. Aho A., Seti R., Ul'man D. Kompilyatory: Prin-cipy, tekhnologii, instrumenty. M.: Vil'yams; 2008. 1184 p. (In Russ.).

Информация об авторах:

А. О. Корзников - бакалавр Пермского государственного национального исследовательского университета (614068, Россия, г. Пермь, ул. Букирева, 15), AuthorlD 1206068;

Н. Н. Дацун - кандидат физико-математических наук, доцент кафедры математического обеспечения вычислительных систем Пермского государственного национального исследовательского университета (614068, Россия, г. Пермь, ул. Букирева, 15), AuthorlD 734216.

Information about the authors:

A. O. Korznikov - BSc of Perm State University (15, Bukireva St., Perm, Russia, 614068), AuthorlD 1206068;

N. N. Datsun - Candidate of Physical and Mathematical Sciences, Associate Professor of the Department of Mathematical Support of Computing Systems of Perm State University (15, Bukireva St., Perm, Russia, 614068), AuthorlD 734216.

i Надоели баннеры? Вы всегда можете отключить рекламу.