Please open Telegram to view this post
VIEW IN TELEGRAM
❤14👍6🔥4
С их помощью можно автоматически определять тип переменной, изменять элементы контейнера по ссылке, безопасно обходить коллекции без копирования, удобно распаковывать пары и кортежи
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
🤝29🔥11❤6
🔥9👍4❤1
is_constant_evaluated для выбора поведения при компиляции!
Сейчас научимся определять, выполняется ли код на этапе компиляции или уже в рантайме — с помощью встроенной функции
Это особенно полезно, когда одна и та же функция может быть вызвана как в
Для начала подключим стандартные библиотеки:
Создадим функцию, которая возвращает разные значения в зависимости от контекста вызова:
Теперь используем эту функцию в двух вариантах:
Результат при запуске программы:
🔥
📣 C++ Ready | #практика
Сейчас научимся определять, выполняется ли код на этапе компиляции или уже в рантайме — с помощью встроенной функции
std::is_constant_evaluated
. Это особенно полезно, когда одна и та же функция может быть вызвана как в
constexpr
контексте, так и в обычном, и нам нужно выполнять разные действия в зависимости от ситуации. Для начала подключим стандартные библиотеки:
#include <iostream>
#include <type_traits>
// std::is_constant_evaluated
Создадим функцию, которая возвращает разные значения в зависимости от контекста вызова:
constexpr int compute() {
if (std::is_constant_evaluated()) {
return 42; // при компиляции
} else {
return 7; // при выполнении
}
}
Теперь используем эту функцию в двух вариантах:
int main() {
constexpr int a = compute();
// constexpr-контекст
int b = compute();
// обычный рантайм
std::cout << "a = " << a << '\n';
std::cout << "b = " << b << '\n';
}
Результат при запуске программы:
a = 42
b = 7
🔥
std::is_constant_evaluated
позволяет адаптировать поведение функций под контекст вызова — выполнять тяжёлые операции заранее и экономить ресурсы в рантайме.Please open Telegram to view this post
VIEW IN TELEGRAM
❤11👍5🔥5
•
std::adjacent_find
— ищет в указанном диапазоне первую пару одинаковых соседних элементов. Возвращает итератор на первый элемент такой пары или end(), если совпадений нет.•
std::generate
— заполняет диапазон значениями, генерируемыми переданной функцией. Полезен для создания тестовых данных или инициализации контейнеров случайными или последовательными значениями.🔥 — если узнал что-то новое
🤝 — если уже пользовался
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥20👍4❤1👎1
Лёгкая функция на C++, которая проверяет строку на совпадение с простым URL‑форматом, извлекает доменное имя и приводит его к нижнему регистру.
В этой задаче:
• Базовая валидация: убеждаемся, что в строке есть хотя бы одна точка и нет пробелов.
• Определение начала: ищем «://» — если протокол указан, начинаем сразу после него, иначе с начала строки.
• Извлечение домена: обрезаем строку по первому слэшу после начала (или до конца).
Это позволяет надёжно получить доменное имя из самых разных URL‑строк и сразу сообщить об ошибке при некорректном вводе.
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥15❤6👍6
Это архитектурный стиль, где ресурсы адресуются понятными URI, а операции над ними выполняются стандартными HTTP‑методами.
Хороший дизайн включает понятное именование, пагинацию, фильтрацию и версионирование.
Сохрани, чтобы не забыть!
Please open Telegram to view this post
VIEW IN TELEGRAM
❤5👍4🔥4
Разбираем безопасное побитовое преобразование типов!
Сейчас научимся преобразовывать данные одного типа в другой без неопределённого поведения — с помощью функции
Сначала подключим необходимые библиотеки из стандартной поставки:
Теперь создадим число с плавающей точкой и преобразуем его в
Преобразуем обратно, чтобы убедиться, что значение не потеряно:
Результат при запуске программы:
🔥 Таким образом ты можешь безопасно перепаковывать данные между типами одинакового размера — без UB, memcpy и хаков.
📣 C++ Ready | #практика
Сейчас научимся преобразовывать данные одного типа в другой без неопределённого поведения — с помощью функции
std::bit_cast
.Сначала подключим необходимые библиотеки из стандартной поставки:
#include <bit> // std::bit_cast
#include <cstdint> // uint32_t
#include <iostream>
#include <iomanip> // std::hex, std::setw, std::setfill
Теперь создадим число с плавающей точкой и преобразуем его в
uint32_t
, чтобы увидеть его внутреннее битовое представление:float value = 3.1415926f;
uint32_t raw = std::bit_cast<uint32_t>(value);
std::cout << "Биты числа: 0x"
<< std::hex << std::setw(8) << std::setfill('0') << raw << '\n';
Преобразуем обратно, чтобы убедиться, что значение не потеряно:
float restored = std::bit_cast<float>(raw);
std::cout << std::dec << "Восстановлено: " << restored << '\n';
Результат при запуске программы:
Биты числа: 0x40490fda
Восстановлено: 3.14159
🔥 Таким образом ты можешь безопасно перепаковывать данные между типами одинакового размера — без UB, memcpy и хаков.
Please open Telegram to view this post
VIEW IN TELEGRAM
❤14👍11🔥6
This media is not supported in your browser
VIEW IN TELEGRAM
Здесь вы найдёте пошаговое изучение языка: от первых программ и базового синтаксиса до работы с функциями, памятью, указателями, шаблонами и отладкой кода. Материалы
сопровождаются примерами, разбором типичных ошибок и краткими тестами для самопроверки.
Please open Telegram to view this post
VIEW IN TELEGRAM
❤10👍5🔥4
Инициализация захватов через
[x = expr]
позволяет перемещать объекты внутрь лямбд, хранить внутреннее состояние и выполнять вычисления в момент захвата.Что важно знать:
• [p = std::move(ptr)] — лямбда получает ресурс, указатель становится пустым.
• [data = heavyInit()] — захватываем результат функции или любое выражение.
• [id = 0]() mutable { return ++id; } — создаём локальный счётчик без глобальных переменных.
Это делает лямбды гибким инструментом, упрощая управление ресурсами и локальным состоянием.
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥12❤6👍4