Отладка c visual studio code

Обновлено: 05.07.2024

В этом пошаговом руководстве рассматриваются возможности отладчика Visual Studio. Более полное описание функций отладчика см. в статье c Знакомство с отладчиком Visual Studio. Отладка приложения обычно означает запуск и выполнение приложения с подключенным отладчиком. При этом в отладчике доступно множество способов наблюдения за выполнением кода. Вы можете пошагово перемещаться по коду и просматривать значения, хранящиеся в переменных, задавать контрольные значения для переменных, чтобы отслеживать изменение значений, изучать путь выполнения кода, просматривать выполнение ветви кода и т. д. Если вы не знакомы с процессом отладки, перед выполнением задач в этой статье рекомендуется прочесть документ об отладке для начинающих.

В этом руководстве рассмотрены следующие задачи:

  • Запуск отладчика и попадание в точки останова.
  • Использование команд для пошагового выполнения кода в отладчике.
  • Проверка переменных в подсказках к данным и окнах отладчика.
  • Просмотр стека вызовов

Предварительные требования

У вас должна быть установлена среда Visual Studio 2019 и должна иметься рабочая нагрузка Разработка классических приложений на C++ .

У вас должна быть установлена среда Visual Studio 2017 и должна иметься рабочая нагрузка Разработка классических приложений на C++ .

Установите Visual Studio бесплатно со страницы скачиваемых материалов Visual Studio, если еще не сделали этого.

Установите Visual Studio бесплатно со страницы скачиваемых материалов Visual Studio, если еще не сделали этого.

Установите Visual Studio 2022 бесплатно со страницы скачиваемых материалов Visual Studio 2022, если еще не сделали этого.

Если вам нужно установить рабочую нагрузку, но вы уже используете Visual Studio, выберите пункт Средства > Получить средства и компоненты. , после чего запустится Visual Studio Installer. Запускается Visual Studio Installer. Выберите рабочую нагрузку Разработка классических приложений на C++ , а затем нажмите Изменить.

Создание проекта

Сначала вы создадите проект консольного приложения на C++. Для этого типа проекта уже имеются все нужные файлы шаблонов, что избавляет вас от лишней работы.

Откройте Visual Studio 2017.

В верхней строке меню последовательно выберите Файл > Создать > Проект.

В левой области диалогового окна Новый проект разверните узел Visual C++ и выберите Рабочий стол Windows. В средней области выберите Консольное приложение Windows. Назовите проект get-started-debugging.

Новый проект открывается в Visual Studio.

Запустите Visual Studio 2019.

Если окно запуска не открыто, выберите Файл > Окно запуска.

На начальном экране выберите Создать проект.

В поле поиска окна Создание проекта введите консоль. Затем выберите C++ в списке языков и Windows в списке платформ.

Применив фильтры языка и платформы, выберите шаблон Консольное приложение и нажмите кнопку Далее.

Выбор шаблона C++ для консольного приложения

В поле Имя проекта окна Настроить новый проект введите get-started-debugging. Затем нажмите Создать.

Новый проект открывается в Visual Studio.

Создание приложения

Откройте файл get-started-debugging.cpp и замените все его содержимое по умолчанию следующим кодом:

Запуск отладчика

Начать отладку

Нажмите клавишу F5 (Отладка > Начать отладку) или кнопку Начать отладку на панели инструментов отладки.

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

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

Остановить отладку

Остановите отладчик, нажав красную кнопку остановки (SHIFT + F5).

В окне консоли нажмите клавишу ВВОД, чтобы закрыть его.

Установка точки останова и запуск отладчика

В цикле for функции main установите точку останова, щелкнув левое поле следующей строки кода:

Точка останова

В месте установки точки останова появится красный круг .

Точки останова — это один из самых простых и важных компонентов надежной отладки. Точка останова указывает, где Visual Studio следует приостановить выполнение кода, чтобы вы могли проверить значения переменных или поведение памяти либо выполнение ветви кода.

Начать отладку

Нажмите клавишу F5 или кнопку Начать отладку. Запустится приложение и отладчик перейдет к строке кода, где задана точка останова.

Установка точки останова и попадание в нее

Желтая стрелка представляет оператор, на котором приостановлен отладчик. В этой же точке приостанавливается выполнение приложения (этот оператор пока не выполнен).

Если приложение еще не запущено, клавиша F5 запускает отладчик и останавливается в первой точке останова. В противном случае F5 продолжает выполнение приложения до следующей точки останова.

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

Переход по коду в отладчике с помощью пошаговых команд

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

Во время приостановки в цикле for в методе main дважды нажмите клавишу F11 (или выберите Отладка > Шаг с заходом), чтобы перейти в вызов метода SendMessage .

После двойного нажатия клавиши F11 вы должны находиться на следующей строке кода:

Еще раз нажмите клавишу F11, чтобы выполнить шаг с заходом в метод SendMessage .

Желтый указатель перемещается в метод SendMessage .

Использование клавиши F11 для перехода в код

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

Предположим, что вы закончили изучать метод SendMessage и хотите выйти из него, но остаться в отладчике. Это можно сделать с помощью команды Шаг с выходом.

Нажмите сочетание клавиш SHIFT + F11 (или Отладка > Шаг с выходом).

Эта команда возобновляет выполнение приложения (и работу отладчика) до возврата данных текущим методом или текущей функции.

Вы должны вернуться в цикл for в методе main , приостановленный на вызове метода SendMessage .

Нажмите клавишу F11 несколько раз, пока не вернетесь к вызову метода SendMessage .

Во время приостановки на вызове метода один раз нажмите клавишу F10 (или выберите Отладка > Шаг с обходом).

Использование клавиши F10 для обхода кода

Обратите внимание, что в этот раз отладчик не заходит в метод SendMessage . Клавиша F10 перемещает отладчик без захода в функции или методы в коде приложения (код продолжает выполняться). Нажав клавишу F10 (а не F11) в вызове метода SendMessage , мы пропускаем код реализации для SendMessage (пока это нас не интересует). Дополнительные сведения о различных способах перемещения по коду см. в разделе Навигация по коду в отладчике.

Переход по коду с помощью команды "Выполнение до щелкнутого"

Нажмите клавишу F5, чтобы перейти к точке останова.


В редакторе кода прокрутите вниз и наведите указатель мыши на функцию std::wcout в методе SendMessage , чтобы в левой части появилась зеленая кнопка Выполнение до щелкнутого. В подсказке для кнопки выводится "Выполнить до этого места".

Использование функции выполнения до щелкнутого

Кнопка Выполнение до щелкнутого впервые появилась в Visual Studio 2017. (Если кнопка с зеленой стрелкой отсутствует, воспользуйтесь клавишей F11, чтобы переместить отладчик в нужное место.)

Отладчик перемещается к функции std::wcout .

Использование этой кнопки аналогично установке временной точки останова. Функция Выполнение до щелкнутого удобна для быстрой работы в видимой области кода приложения (можно щелкнуть в любом открытом файле).

Быстрый перезапуск приложения

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

Отладчик еще раз останавливается в точке останова, ранее заданной вами в цикле for .

Проверка переменных с помощью подсказок по данным

Функции, позволяющие проверять переменные, являются самыми полезными возможностями отладчика. Реализовывать эту задачу можно разными способами. Часто при попытке выполнить отладку проблемы пользователь старается выяснить, хранятся ли в переменных значения, которые требуются ему в определенное время.

При приостановке на операторе name += letters[i] наведите указатель мыши на переменную letters и увидите ее значение по умолчанию — size= .

Разверните переменную letters , чтобы просмотреть ее свойства, включая все элементы, которые она содержит.

Затем наведите указатель мыши на переменную name , чтобы просмотреть ее текущее значение — пустую строку.

Несколько раз нажмите клавишу F5 (или выберите Отладка > Продолжить), чтобы выполнить несколько итераций по циклу for , каждый раз снова приостанавливая выполнение в точке останова и наводя указатель мыши на переменную name , чтобы просмотреть ее значение.

Просмотр подсказок по данным

Значение переменной изменяется при каждой итерации цикла for — f , затем fr , fre и т. д.

Часто при отладке требуется быстро проверить значения свойств в переменных, чтобы убедиться, что в них хранятся ожидаемые значения. Советы по данным — отличный способ это сделать.

Проверка переменных с помощью окон "Видимые" и "Локальные"

Взгляните на окно Видимые в нижней части редактора кода.

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

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

Затем посмотрите на окно Локальные на вкладке рядом с окном Видимые.

Разверните переменную letters , чтобы отобразить элементы, которые она содержит.

Проверка переменных в окне локальных переменных

В окне Локальные показаны переменные, которые находятся в текущей области, то есть текущем контексте выполнения.

Установка контрольного значения

В основном окне редактора кода щелкните правой кнопкой мыши переменную name и выберите команду Добавить контрольное значение.

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

Теперь у вас есть контрольное значение, заданное для переменной name , и по мере перемещения по отладчику вы можете наблюдать за изменением его значения. В отличие от других окон переменных, в окне Контрольное значение всегда отображаются просматриваемые вами переменные (они выделяются серым цветом, когда находятся вне области действия).

Просмотр стека вызовов

Во время приостановки в цикле for щелкните окно Стек вызовов, которое по умолчанию открыто в нижней правой области.

Если оно закрыто, откройте его во время приостановки в отладчике, выбрав Отладка > Окна > Стек вызовов.

Несколько раз нажмите клавишу F11, пока отладчик не приостановится в методе SendMessage . Взгляните на окно Стек вызовов.

Изучение стека вызовов

В окне Стек вызовов показан порядок вызова методов и функций. В верхней строке приведена текущая функция (в данном приложении метод SendMessage ). Во второй строке показано, что функция SendMessage была вызвана из метода main и т. д.

Окно Стек вызовов аналогично перспективе "Отладка" в некоторых интегрированных средах разработки, например Eclipse.

Стек вызовов хорошо подходит для изучения и анализа потока выполнения приложения.

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

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

Изменение потока выполнения

Дважды нажмите клавишу F11, чтобы запустить функцию std::wcout .

Приостановив отладчик в вызове метода SendMessage , с помощью мыши захватите желтую стрелку (указатель выполнения) в левой части и переместите ее вверх на одну строку — обратно в std::wcout .

Нажмите клавишу F11.

Отладчик повторно выполнит функцию std::wcout (вы увидите это в выходных данных окна консоли).

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

Как правило, при работе с этой функцией необходимо соблюдать осторожность — вы увидите соответствующее предупреждение во всплывающей подсказке. Могут отображаться и другие предупреждения. При перемещении указателя предыдущее состояние приложения не возвращается.

Чтобы продолжить выполнение приложения, нажмите клавишу F5.

Поздравляем с завершением этого учебника!

Следующие шаги

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

Запишите основной процесс отладки программ C / C ++ с помощью VS Code, чтобы углубить понимание построения, компиляции и компоновки проекта. По моему собственному опыту, он не подходит для использования в реальных проектах.Если у меня нет глубокого понимания конструкции проекта make-файла и цепочек инструментов, связанных с C / C ++, его трудно контролировать.

Создание среды отладки VS Code C / C ++

Согласно «Справочнику 1» для создания среды отладки VS Code C / C ++, общий процесс выглядит следующим образом:

 C/C++

  1. Установить VS CODE
    VSCODE - это бесплатная платформа Microsoft для кроссплатформенной разработки, которую можно загрузить и установить с ее официального сайта;
  2. Установите подключаемый модуль Microsoft C / C ++
    • Откройте VS Code.
    • Щелкните значок расширения на левой панели инструментов.
    • Найдите c ++.
    • Нажмите Install, перезапустите VSCODE после soft.

      После установки подключаемого модуля, когда вы откроете папку, содержащую исходный код C / C ++, VSCODE автоматически добавит подкаталог, содержащий файл настроек. Vscode

Обратите внимание, что подключаемый модуль C / C ++ от Microsoft не включает компилятор и отладчик C ++. Их необходимо установить самостоятельно. Обычно используемые компиляторы C ++ включают mingw-w64 под Windows, Clang для XCode под macOS и GCC под linux, Windows Необходимо добавить адрес установки цепочки инструментов в переменную среды PATH.

  1. Настроить IntelliSense
    После открытия соответствующей папки подключаемый модуль Microsoft C / C ++ попытается предоставить базовую конфигурацию в соответствии с компилятором системы. Если конфигурация не удалась, вам необходимо самостоятельно сгенерировать файл конфигурации c_cpp_properties.json. Методы, указанные ниже:
  • Откройте командную панель (Ctrl + Shift + P или меню [View] -> [Command Panel])
  • Выполните команду C / Cpp: Edit configurations .
  • Сгенерируйте c_cpp_properties.json, файл конфигурации сохраняется в папке .vscode
    Ниже приведен файл конфигурации по умолчанию c_cpp_properties.json, созданный компилятором MinGW C ++ под Windows.
  1. Код сборки
    Если вы хотите создать код, вам необходимо настроить файл task.json:
    • Откройте командную панель (Ctrl + Shift + P или меню [View] -> [Command Panel])
    • Выберите команду Tasks: Configure Tasks . щелкните, чтобы создать файл tasks.json, вы увидите серию шаблонов запуска задач.
    • Выбрать шаблон Другое: Примеры запуска произвольных внешних команд
    • Измените выражение командной строки для построения кода, например g ++
    • Добавьте необходимые аргументы (например, -g для отладки)
    • Измените метку, чтобы сделать ее описательной
      пример кода tasks.json, как показано ниже:

Если вы хотите собрать код через меню [Задачи] -> [Выполнить задачу сборки . ] или с помощью сочетания клавиш (Ctrl + shift + B), вам нужно добавить групповую сборку в файл tasks.json прямо сейчас, как показано ниже, чтобы вы могли собрать код Создайте исполняемый файл:

  1. Код отладки
    отладки, вам необходимо сгенерировать файл launch.json:
    • Щелкните значок отладки на левой панели инструментов.
    • В представлении отладки щелкните значок Настроить
    • Выберите C ++ (GDB / LLDB), чтобы создать файл launch.json, есть два элемента конфигурации
      • C ++ Launch определяет свойства, когда вы начинаете отладку и загружаете приложение.
      • C ++ Attach определяет присоединенные свойства запущенного процесса
    • Обновите атрибуты программы, добавьте свой каталог отладки
    • Если вы хотите создать свой собственный код перед отладкой, вам необходимо добавить атрибут preLaunchTask, содержимое которого является меткой задачи, только что созданной в task.json (например, предыдущий «build hello world»)
      Ниже приводится содержимое файла конфигурации launch.json с использованием отладчика MinGW GDB:

На этом этапе щелкните значок отладки на левой панели инструментов, а затем щелкните зеленый значок запуска, чтобы построить код -> программа отладки. В этот момент вы можете увидеть «привет, мир» в терминале!

Отладка простой программы на C / C ++

Теория без практики - это замок в небе.

  1. Создать и открыть исходную файловую структуру
  • Создать новый каталог ex
  • Создайте в каталоге новый файл hello.cpp следующим образом:
  • Откройте VSCODE, [Файл] -> [Открыть папку], чтобы открыть папку.
  1. Настроить IntelliSense
    Откройте панель команд (Ctrl + Shift + P или меню [View] -> [Command Panel]), запустите команду C / Cpp: Edit configurations . для создания c_cpp_properties.json, Файл конфигурации сохраняется в папке .vscode. Ниже приведен файл конфигурации по умолчанию c_cpp_properties.json, созданный компилятором GCC под Linux:

Следует обратить внимание на две вещи: «includePath» - это каталог включенных файлов, установленный в соответствии со структурой исходного кода, потому что исходный код - это просто файл hello.cpp, устанавливать не нужно, значение по умолчанию ОК; «compilerPath» - это каталог компилятора, согласно Необходимо изменить

  1. Код сборки
  • Создайте новую задачу сборки.Роль этой задачи заключается в предоставлении сценария для компиляции ссылок.Личное понимание, после выполнения этой задачи целевой файл будет сгенерирован в локальном каталоге.
  • Меню [Задачи] -> [Выполнить задачу сборки . ], вам будет предложено, что задача сборки не найдена, вам нужно настроить задачу сборки, вы можете только выполнить задачу, следуя инструкциям, создайте файл конфигурации задачи сборки с другими в качестве шаблона tasks.json выглядит следующим образом:
  • Меню [Задачи] -> [Запустить задачу сборки . ], выполнить задачу компиляции ссылки, настроенной выше, фактически выполняется команда компиляции

g++ -g ex.cpp -o qb.out
В это время сгенерированный целевой файл qb.out можно найти в каталоге

  1. Код отладки
  • Щелкните значок отладки на левой панели инструментов -> значок «Настроить» -> выберите C ++ (GDB / LLDB), чтобы сгенерировать файл launch.json,
  • Щелкните зеленый значок запуска для отладки, ОК!

Отладка программ C / C ++, созданная Makefile

VS Code взаимодействует с Makefile для улучшения переносимости проектов C / C ++. Идея этого решения такова: используйте Makefile для сборки проекта, VS Code вызывает инструмент make через Tasks для компиляции и вызывает gdb для отладки. Преимущество заключается в том, что он не слишком сильно зависит от конфигурации самого VS Code.Подходящий Makefile может быть скомпилирован на различных платформах, но удобство, обеспечиваемое собственными плагинами VS Code, можно использовать в процессе разработки, сокращая ввод команд и командные строки. Проблемы, вызванные отладкой GDB.

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

Отладка встроенной программы STM32

JLINK

СправкаИспользуйте VSCode и VS2017 для компиляции и отладки программ STM32, Может быть загружен и запущен, но не может быть отлажен в обычном режиме.

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

Поскольку мне всё равно пришлось ставить Visual Studio Community для того, чтобы установить Windows Kits для работы с WinAPI, то я решил не использовать MingW, а доустановить C++ build tools и использовать их для компиляции. В этом случае придётся переделать задачи (tasks) и настройки VSCode.

Хорошее описание нашёл здесь, его и буду использовать в данной заметке.

Нам потребуется


1. Естественно нам потребуется сама программа VSCode.
2. В Visual Studio Community должен быть установлен компонент Desktop development with C++ :

Чтобы проверить успешную установку, достаточно вызвать Developer Command Prompt for VS 2019 (файл VsDevCmd.bat ) из Пуска. Там нужно запустить файл cl.exe . Вывод консоли должен быть без ошибок:

3. Для VSCode должно быть установлено дополнение (расширение) Microsoft C/C++

Настройка

4. В Проводнике открываем рабочую папку проекта и, удерживая Shift , нажимаем правую кнопку мыши, после чего выбираем Open PowerShell window here
5. В открывшемся окошке PowerShell запускаем VSCode, для этого нужно набрать code . и нажать Enter :

Шаги 9-11 скорее всего не нужны. В статье они есть, но без них у меня всё тоже прекрасно компилируется.


9. Открываем палитру команд с помощью комбинации клавиш Ctrl + Shift + P
10. Список большой, поэтому проще ввести часть слова и выбрать нужную команду Edit Configurations UI из списка:

11. В конфигурации необходимо проверить, а, при необходимости, установить путь для компилятора:



12. Внесём изменения в файл settings.json :

У меня глобальный файл настроек, а не только для проекта, поэтому я добавляю строчки в начало файла C:\Users\Denis\AppData\Roaming\Code\User\settings.json

13. Ранее я уже создавал файл Задач tasks.json, поэтому сейчас я добавлю к нему новые строчки:

14. Чтобы у нас была возможность запустить проект на отладку, можно использовать файл launch.json . Но я не хочу создавать такой файл для каждого проекта каждый раз, поэтому сделаю глобальную конфигурацию. Для этого я добавлю строчки в файл settings.json :

Благодаря этому, при нажатии F5 , проект будет откомпилирован, а потом запущен сразу после этого. Просто запустить, без отладки, можно комбинацией Ctrl + F5

Lorem ipsum dolor

Отладка кода в Visual Studio происходит довольно просто, если сравнивать это т процесс с другими IDE. Плюс отладчик Visual Studio обладает довольно широкими возможностями и позволяет отлаживать различные технологии, а если имеющихся средств не хватает, то можно воспользоваться дополнениями.

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

В то же время отладка кода — это не волшебная палочка, которая быстренько найдет и исправит все недочеты вашего кода. Отладка — это процесс, при котором код пошагово выполняется в некой программе, например , в Visual Studio. В процессе выполнения идет поиск точек, где вы могли допустить ошибку. А вы в это время можете анализировать свой код и вносить необходимые правки для устранения «косяков».

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

Отладка кода в Visual Studio

  • орфографические ошибки или опечатки,
  • неправильно подключенные API,
  • неправильное размещение последних корректировок в код,
  • и др.
  • ошибка компиляции;
  • ошибка преобразования типа;
  • код не поддерживает синтаксис;
  • и др .

Как запустить отладчик Visual Studio

  1. Запустить саму программу Visual Studio.
  2. Откр ыть код приложения, который необходимо отладить.
  3. Потом при помощи нажатия клавиши «F5» запустить режим отладки. Также это можно сделать через меню, если нажать «Отладка», а потом «Начать отладку» .
  • последовательность исполнения кода;

  • работу памяти;

  • значение переменных и др.

Какая информация выводится отладчиком Visual Studio

В заключение

Отладка в Visual Studio дает возможность довольно быстро решить проблемы с вашим кодом. Да, без определенных знаний и понимания запустить и понять отладчик Visual Studio будет нелегко, но с опытом все станет понятнее. В разработке без отладки кода — путь в никуда , п отому что стабильность работы приложения — это залог его качества. И если на самом старте разработк и игнорировать этот процесс, то нет смысла идти дальше.

Мы будем очень благодарны

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

Читайте также: