C/C++ Ready | Программирование
11.6K subscribers
692 photos
41 videos
334 links
Авторский канал по разработке на C и C++.
Ресурсы, гайды, задачи, шпаргалки.
Информация ежедневно пополняется!

Автор: @energy_it

Реклама на бирже: https://telega.in/c/cpp_ready
加入频道
This media is not supported in your browser
VIEW IN TELEGRAM
☕️ Code․mu Tasker — бесплатный практический задачник по плюсам!

Здесь собрано 100 упражнений, распределённых по 10 уровням, которые помогут вам отработать базовые конструкции языка, принципы ООП, работу с библиотекой STL, алгоритмы и многое другое.

📌 Оставляю ссылочку: code.mu

📣 C++ Ready | #ресурс
Please open Telegram to view this post
VIEW IN TELEGRAM
14👍6🔥4
👩‍💻 Разберём циклы с диапазоном и auto — способ проходить по контейнеру без индексов и явных итераторов!

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

📣 C++ Ready | #шпора
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
🤝29🔥116
Что же выведет консоль?
Anonymous Quiz
40%
A
23%
B
18%
C
19%
D
🔥9👍41
is_constant_evaluated для выбора поведения при компиляции!

Сейчас научимся определять, выполняется ли код на этапе компиляции или уже в рантайме — с помощью встроенной функции 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 позволяет адаптировать поведение функций под контекст вызова — выполнять тяжёлые операции заранее и экономить ресурсы в рантайме.

📣 C++ Ready | #практика
Please open Telegram to view this post
VIEW IN TELEGRAM
11👍5🔥5
👩‍💻 Познакомимся с двумя методами для работы с диапазонами!

std::adjacent_find — ищет в указанном диапазоне первую пару одинаковых соседних элементов. Возвращает итератор на первый элемент такой пары или end(), если совпадений нет.

std::generate — заполняет диапазон значениями, генерируемыми переданной функцией. Полезен для создания тестовых данных или инициализации контейнеров случайными или последовательными значениями.

🔥 — если узнал что-то новое
🤝 — если уже пользовался


📣 C++ Ready | #метод
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥20👍41👎1
👩‍💻 Пишем экстрактор домена из URL и нормализация регистра!

Лёгкая функция на C++, которая проверяет строку на совпадение с простым URL‑форматом, извлекает доменное имя и приводит его к нижнему регистру.

В этой задаче:

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

Определение начала: ищем «://» — если протокол указан, начинаем сразу после него, иначе с начала строки.

Извлечение домена: обрезаем строку по первому слэшу после начала (или до конца).


Это позволяет надёжно получить доменное имя из самых разных URL‑строк и сразу сообщить об ошибке при некорректном вводе.

📣 C++ Ready | #задача
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥156👍6
📂 Напоминалка по дизайну REST API архитектуры!

Это архитектурный стиль, где ресурсы адресуются понятными URI, а операции над ними выполняются стандартными HTTP‑методами.

Хороший дизайн включает понятное именование, пагинацию, фильтрацию и версионирование.

Сохрани, чтобы не забыть!

📣 C++ Ready | #ресурс
Please open Telegram to view this post
VIEW IN TELEGRAM
5👍4🔥4
Разбираем безопасное побитовое преобразование типов!

Сейчас научимся преобразовывать данные одного типа в другой без неопределённого поведения — с помощью функции 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 и хаков.

📣 C++ Ready | #практика
Please open Telegram to view this post
VIEW IN TELEGRAM
14👍11🔥6
This media is not supported in your browser
VIEW IN TELEGRAM
😎 radioprog — бесплатный учебник по программированию, подходящий для тех, кто хочет систематизировать знания!

Здесь вы найдёте пошаговое изучение языка: от первых программ и базового синтаксиса до работы с функциями, памятью, указателями, шаблонами и отладкой кода. Материалы сопровождаются примерами, разбором типичных ошибок и краткими тестами для самопроверки.

📌 Оставляю ссылочку: radioprog.ru

📣 C++ Ready | #ресурс
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; } — создаём локальный счётчик без глобальных переменных.


Это делает лямбды гибким инструментом, упрощая управление ресурсами и локальным состоянием.

📣 C++ Ready | #гайд
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥126👍4