Jump to content

Меры сложности Холстеда

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

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

Для данной задачи пусть:

  • = количество различных операторов
  • = количество различных операндов
  • = общее количество операторов
  • = общее количество операндов

Из этих цифр можно рассчитать несколько показателей:

  • Словарь программы:
  • Продолжительность программы:
  • Расчетная предполагаемая продолжительность программы:
  • Объем:
  • Сложность:
  • Усилие:

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

Мера усилий переводится в фактическое время кодирования с использованием следующего соотношения:

  • Время, необходимое для программирования: секунды

Доставленные Холстедом ошибки (B) — это оценка количества ошибок в реализации.

  • Количество доставленных ошибок: или, совсем недавно, принято. [1]

Рассмотрим следующую программу на языке C :

main()
{
  int a, b, c, avg;
  scanf("%d %d %d", &a, &b, &c);
  avg = (a+b+c)/3;
  printf("avg = %d", avg);
}

Отдельные операторы ( ) являются: main, (), {}, int, scanf, &, =, +, /, printf, ,, ;

Отдельные операнды ( ) являются: a, b, c, avg, "%d %d %d", 3, "avg = %d"

  • , ,
  • , ,
  • Расчетная предполагаемая продолжительность программы:
  • Объем:
  • Сложность:
  • Усилие:
  • Время, необходимое для программирования: секунды
  • Количество доставленных ошибок:

См. также

[ редактировать ]
  1. ^ Перейти обратно: а б Холстед, Морис Х. (1977). Элементы науки о программном обеспечении . Elsevier North-Holland, Inc. Амстердам: ISBN  0-444-00205-7 .
[ редактировать ]
Arc.Ask3.Ru: конец переведенного документа.
Arc.Ask3.Ru
Номер скриншота №: ceb788bf486b87e51ab4229306a5303d__1704372480
URL1:https://arc.ask3.ru/arc/aa/ce/3d/ceb788bf486b87e51ab4229306a5303d.html
Заголовок, (Title) документа по адресу, URL1:
Halstead complexity measures - Wikipedia
Данный printscreen веб страницы (снимок веб страницы, скриншот веб страницы), визуально-программная копия документа расположенного по адресу URL1 и сохраненная в файл, имеет: квалифицированную, усовершенствованную (подтверждены: метки времени, валидность сертификата), открепленную ЭЦП (приложена к данному файлу), что может быть использовано для подтверждения содержания и факта существования документа в этот момент времени. Права на данный скриншот принадлежат администрации Ask3.ru, использование в качестве доказательства только с письменного разрешения правообладателя скриншота. Администрация Ask3.ru не несет ответственности за информацию размещенную на данном скриншоте. Права на прочие зарегистрированные элементы любого права, изображенные на снимках принадлежат их владельцам. Качество перевода предоставляется как есть. Любые претензии, иски не могут быть предъявлены. Если вы не согласны с любым пунктом перечисленным выше, вы не можете использовать данный сайт и информация размещенную на нем (сайте/странице), немедленно покиньте данный сайт. В случае нарушения любого пункта перечисленного выше, штраф 55! (Пятьдесят пять факториал, Денежную единицу (имеющую самостоятельную стоимость) можете выбрать самостоятельно, выплаичвается товарами в течение 7 дней с момента нарушения.)