c-cpp-cookies
  • Полезные материалы
    • About
  • Настройка окружения
    • Git
      • Git CLI
      • Git GUI
      • Git Web
      • Git в среде разработке
        • Visual Studio
        • Visual Studio Code
        • CLion
        • Qt Creator
    • Стандарты (они же ISO)
    • Qt about
    • IDE
      • Visual Studio Code
        • Код в Visual Studio Code
        • Разработка в Visual Studio Code
      • Visual Studio
        • Настройки Visual Studio и проектов
        • Код в Visual Studio
        • Visual Studio + GitHub
      • Qt + Qt Creator
        • Установка Qt и QtCreator
        • Примеры проектов на Qt
      • CLion
        • Настройки CLion
        • Код в CLion
        • CLion + GitHub
    • Компиляторы
      • Clang + Visual Studio
      • Clang + CLion
  • Best practices
    • Антипаттерны и способы улучшения кода
      • 0. Освобождение ресурсов
      • 1. Чтение данных из файла
      • 2. Открытие файлов
      • 3. Объявление переменных
      • 4. Выделение памяти
      • 5. Необдуманный код
      • 6. Глубокие if
      • 7. Длинные if
      • 9. Non-void функции
      • 10. Создание массивов
      • 11. Проверка формата файла
  • Сборка программы
    • Сборка программы
    • Системы сборки / Build systems
      • Проект и решение
      • Make
      • Ninja
      • CMake
      • MSBuild
    • Подключение внешних библиотек
    • Библиотеки
  • Отладка
    • Отладка / Debugging
    • Запуск программы
    • Точки останова / Breakpoints
      • Обычные точки останова / General breakpoint
      • Условные точки останова / Conditional breakpoint
      • Зависимые точки останова / Dependent breakpoint
      • Временные точки останова / Temporary breakpoint
      • Точки трассировки / Breakpoint actions и tracepoints
    • Стек вызовов / Call stack
    • Локальные переменные / Locals
    • Просмотр области памяти / Memory view
    • Исключения / Exceptions
  • Анализ
    • Поиск утечек памяти
    • Санитайзеры
  • Возможности IDE
    • Возможности IDE
    • Продвинутый текстовый редактор
    • Закладки / Bookmarks
    • Платформы / Platforms
    • Конфигурации сборки / Build configurations
    • Шаблонные проекты / Project templates
    • Терминал / Terminal
    • Сборка / Build
    • Запуск программы / Run program
    • Code style
    • Работа с Github Actions
  • Тестирование
    • Тестирование
    • Google test
      • Gtest в VS
      • Gtest в CLion
      • Gtest в VSCode
    • Покрытие кода (code coverage)
Powered by GitBook
On this page
  1. Best practices
  2. Антипаттерны и способы улучшения кода

6. Глубокие if

Previous5. Необдуманный кодNext7. Длинные if

Last updated 6 months ago

int main(int argc, char *argv[])
{
    if (fopen(argv[1], "r"))
    {
        int size;
        if (fscanf("%d\n", &size) == 1)
        {
            char *arr = malloc(size);
            if (arr != NULL)
            {
                // etc.
            }
            else
            {
                // memory allocation failed
                return 1;
            }
        }
        else
        {
            // cannot open input file
            return 1;
        }
    }
    else
    {
        // cannot open input file
        return 1;
    }
    return 0;
}
Вариант реорганизации и исправления кода

Большая вложенность условий, циклов и пр. пагубно влияет на просматривающих код, т.к. всегда требуется держать в голове при каких таких условиях мы попали сюда.

int main(int argc, char *argv[])
{
    if (!fopen(argv[1], "r"))
    {
        // cannot open input file
        return 1;
    }
    int size;
    if (fscanf("%d\n", &size) != 1)
    {
        // cannot open input file
        return 1;
    }
    char *arr = malloc(size);
    if (arr == NULL)
    {
        // memory allocation failed
        return 1;
    }
    // etc.
    return 0;
}
3KB
.clang-format
Весь приведённый далее код оформлен с использованием clang-format