Number of Paths

Предполагаемое статическое количество пути

Описание

Эта метрика измеряет количество путей в функции.

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

Осуществлять пределы на метриках:

Детали расчета

Количество путей вычисляется согласно этим правилам:

  • Если операторы в функции не повреждают поток управления, количество путей является тем.

    Даже пустой оператор, такой как ; или пустой блок, такой как {} количества как один путь.

  • Оператор управления вводит ветви и добавляет к исходному одному пути.

    • if-else if-else: Каждый if ключевое слово вводит новую ветвь. Вклад от if-else if-else блок является количеством ветвей плюс одна (исходный путь). Если всеобъемлющий else присутствует, все пути проходят блок; в противном случае один путь обходит блок.

      Например, функция с if(..) {} else if(..) {} else {} оператор имеет три пути. Функция с одним if() {} только имеет два пути, тот, который проходит if блокируйтесь и тот, который обходит блок.

    • switch-case: Каждый case метка, сопровождаемая операторами, вводит новую ветвь. Вклад от switch блок является количеством такого case метки плюс одна (исходный путь). Если всеобъемлющий default присутствует, все пути проходят блок; в противном случае один путь обходит блок.

      Например, функция с оператором switch (var) { case 1: .. break; case 2: .. break; default: .. } имеет три пути, все проходящие switch блок. Если вы не используете default, функция все еще имеет три пути, два прохождения через switch блокируйтесь и один обход блока.

    • forв то время как, и do-while: Каждая инструкция циклов вводит новую ветвь. Вклад от цикла равняется двум - путь, который проходит цикл и путь, который обходит цикл.

    Обратите внимание на то, что оператор с тернарным оператором такой как

    result = a > b ? a : b;
    не рассматривается как оператор, который повреждает поток управления.

  • Если больше чем один оператор управления присутствует в последовательности без какого-либо вложения, количество путей является продуктом вкладов от каждого оператора управления.

    Например, если функция имеет три for циклы и два if-else блоки, один за другим, количество путей является 2 × 2 × 2 × 2 × 2 = 32.

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

  • Программное обеспечение отображает определенные значения в случаях, где метрика не вычисляется:

    • Если goto операторы присутствуют в теле функции, Polyspace не может вычислить количество путей. Программное обеспечение отображает метрическое значение-1.

    • Если количество путей достигает внутреннего предела, остановок вычисления. Программное обеспечение отображает этот предел как метрическое значение. Предел равняется 9223372036854775807 (указание на шестнадцатеричный номер 0x7fffffffffffffff).

Примеры

развернуть все

int func(int ch) {
    return (ch * 2);
}

В этом примере, func имеет один путь.

void func(int ch) {
    switch (ch)
    {
    case 1:
        break;
    case 2:
        break;
    case 3:
        break;
    case 4:
        break;
    default:
    }
}

В этом примере, func имеет пять путей. Кроме пути, который проходит default, каждый case метка, сопровождаемая оператором, вызывает создание нового пути.

void func()
{
    int i = 0, j = 0, k = 0;
    for (i=0; i<10; i++)
    {
        for (j=0; j<10; j++)
        {
            for (k=0; k<10; k++)
            {
                if (i < 2 )
                    ;
                else
                {
                    if (i > 5)
                        ;
                    else
                        ;
                }
            }
        }
    }
}

В этом примере, func имеет шесть путей - три от for операторы, два от if операторы плюс исходный путь, который обходит все операторы управления.

Метрическая информация

Группа: Функция
Акроним: PATH
Метрика HIS: да

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