📰 Свеженькое из мира C++
Подготовили подборку самых интересных материалов за неделю о разных аспектах программирования и интересных проектах в мире C++.
😎 Интересное:
• Минималистичная настройка редактора Zed — плейлист с настройкой редактора
• Vtable изнутри — разбор устройства таблиц виртуальных функций
• Деревья в алгоритмах — гайд по иерархическим структурам
• Бесплатные курсы от MIT — университетские курсы по shell, git и др.
• Иерархический FSM — разбор способа решения проблемы состояний
• GCC 16: наконец-то читаемые ошибки компилятора — обзор улучшений обработки и вывода ошибок
• Улучшения string и string_view в C++26, о которых давно мечтали — исправление костылей
📙 Ranges:
• C++ Ranges. Требования к диапазонам
• std::views::filter — ленивая фильтрация в C++20
• views::transform — ленивые преобразования в C++20
• views::take и views::drop — срезы в C++
🔹📍Навигация: Вакансии • Задачи • Собесы
Библиотека C/C++ разработчика
#свежак
Подготовили подборку самых интересных материалов за неделю о разных аспектах программирования и интересных проектах в мире C++.
😎 Интересное:
• Минималистичная настройка редактора Zed — плейлист с настройкой редактора
Zed для минималистов• Vtable изнутри — разбор устройства таблиц виртуальных функций
• Деревья в алгоритмах — гайд по иерархическим структурам
• Бесплатные курсы от MIT — университетские курсы по shell, git и др.
• Иерархический FSM — разбор способа решения проблемы состояний
• GCC 16: наконец-то читаемые ошибки компилятора — обзор улучшений обработки и вывода ошибок
• Улучшения string и string_view в C++26, о которых давно мечтали — исправление костылей
string_view📙 Ranges:
• C++ Ranges. Требования к диапазонам
• std::views::filter — ленивая фильтрация в C++20
• views::transform — ленивые преобразования в C++20
• views::take и views::drop — срезы в C++
🔹📍Навигация: Вакансии • Задачи • Собесы
Библиотека C/C++ разработчика
#свежак
👍4❤2
🏛️ oo-alloc — пользовательские аллокаторы
Написать аллокатор в C++ несложно. Написать его правильно — уже интереснее.
• Проблема
• Иерархия классов даёт полиморфизм через интерфейс, но добавляет косвенный вызов через таблицу виртуальных функций — и авторы это понимают
• Выделение памяти через пул снижает нагрузку на кучу и устраняет фрагментацию при объектах фиксированного размера
Альтернатива из стандарта —
👉 Github
🖍️ Стоит ли вообще писать кастомный аллокатор в 2026, когда есть
📍 Навигация: Вакансии • Задачи • Собесы
Библиотека C/C++ разработчика
#буст
Написать аллокатор в C++ несложно. Написать его правильно — уже интереснее.
oo-alloc предлагает объектно-ориентированную модель поверх низкоуровневого управления памятью.• Проблема
std::allocator: шаблон привязан к типу, его сложно использовать совместно для разных типов в одном контексте• Иерархия классов даёт полиморфизм через интерфейс, но добавляет косвенный вызов через таблицу виртуальных функций — и авторы это понимают
• Выделение памяти через пул снижает нагрузку на кучу и устраняет фрагментацию при объектах фиксированного размера
Альтернатива из стандарта —
std::pmr::polymorphic_allocator с memory_resource. Тот же полиморфизм, но без overhead своей иерархии и с поддержкой в STL-контейнерах из коробки. Если нужен production-grade вариант — сначала смотреть туда.👉 Github
🖍️ Стоит ли вообще писать кастомный аллокатор в 2026, когда есть
pmr?📍 Навигация: Вакансии • Задачи • Собесы
Библиотека C/C++ разработчика
#буст
❤4👍3🤔1🙏1🥱1
🦾 Почему ваши AI-продукты на базе LLM ломаются (и как это чинить)?
Выкатили ИИ-фичу в прод, а она галлюцинирует, падает или выдает мусор? Приглашаем на открытый вебинар, где разберем реальную боль внедрения LLM-агентов и научимся делать так, чтобы «всё работало».
🗓️ Когда: 14 мая в 19:00 МСК
⏱️ Формат: 60 минут мяса + 30 минут ответов на ваши вопросы
🧑🏻💻 Кто вещает: Эмиль Сатаев — Backend Platform Developer (8+ лет в разработке). Человек, который своими руками внедряет LLM и агентные системы в реальные коммерческие сервисы.
🎁 Главный бонус для онлайна:
Только участникам прямого эфира подарим уникальный промокод на скидку 10.000 ₽ на большой курс AgentOps.
👉 Занять место на вебинаре
Выкатили ИИ-фичу в прод, а она галлюцинирует, падает или выдает мусор? Приглашаем на открытый вебинар, где разберем реальную боль внедрения LLM-агентов и научимся делать так, чтобы «всё работало».
🗓️ Когда: 14 мая в 19:00 МСК
⏱️ Формат: 60 минут мяса + 30 минут ответов на ваши вопросы
🧑🏻💻 Кто вещает: Эмиль Сатаев — Backend Platform Developer (8+ лет в разработке). Человек, который своими руками внедряет LLM и агентные системы в реальные коммерческие сервисы.
🎁 Главный бонус для онлайна:
Только участникам прямого эфира подарим уникальный промокод на скидку 10.000 ₽ на большой курс AgentOps.
👉 Занять место на вебинаре
😁2
В C++23 появился синтаксис auto(x) и auto{x}. Это не очередной сахар для объявления переменных. На самом деле — это именованная операция, у которой есть точная семантика.
auto(x) — это decay-copy: создаётся prvalue того же типа, что и x, но после применения std::decay. То есть:• Ссылки снимаются
• Cv-квалификаторы (const/volatile) удаляются
• Массивы → указатели
• Функции → указатели на функции
const int& r = 42;
auto copy = auto(r); // int, не const int&
auto copy = std::decay_t<decltype(r)>(r);
В простых случаях
auto copy = r тоже даст int — auto и так делает decay. Но в обобщённом коде важно явно сигнализировать намерение: "я хочу копию, а не прокси или view".Главное применение — защита от UB при модификации контейнера. Классический пример — реализация pop_front:
void pop_front(auto& container) {
std::erase(container, auto(container.front()));
// Без auto() — UB: front() может инвалидироваться
// в процессе удаления элементов
}Без auto() мы передаём ссылку на элемент, который erase может разрушить до сравнения. С auto() — сначала создаётся копия значения, потом происходит удаление. Безопасно и читаемо.
📍Навигация: Вакансии • Задачи • Собесы
Библиотека C/C++ разработчика
#константная_правильность
Please open Telegram to view this post
VIEW IN TELEGRAM
❤4🤔4👍2
😆 Платить ИИ за работу меньше, в отличии от человека, не получится
📍Навигация: Вакансии • Задачи • Собесы
Библиотека C/C++ разработчика
#развлекалово
📍Навигация: Вакансии • Задачи • Собесы
Библиотека C/C++ разработчика
#развлекалово
😁10💯4
🔪 Разбиение диапазонов: views::split, chunk, chunk_by
Ranges-библиотека умеет не только фильтровать и трансформировать, но и разбивать диапазоны на части. Разберём три инструмента — каждый для своей задачи.
🍴 views::split — разбивка по разделителю
В C++23 появился
❗️
🥨 views::chunk(n) — разбивка на блоки фиксированного размера (C++23)
❗️ Если размер диапазона не делится на n нацело — последний блок содержит оставшиеся элементы.
🍪 views::chunk_by — разбивка по условию (C++23)
Группирует соседние элементы, пока выполняется предикат между двумя соседями.
❗️ Предикат принимает два соседних элемента — новая группа начинается там, где он вернул false.
📍Навигация: Вакансии • Задачи • Собесы
Библиотека C/C++ разработчика
#константная_правильность
Ranges-библиотека умеет не только фильтровать и трансформировать, но и разбивать диапазоны на части. Разберём три инструмента — каждый для своей задачи.
std::string csv = "один,два,три,четыре";
// Разбиваем по запятой
for (auto part : csv | views::split(',')) {
// part — под-диапазон символов, не строка
// В C++20 явно конструируем string:
std::cout << std::string(part.begin(), part.end()) << "\n";
}
// один
// два
// три
// четыре
В C++23 появился
std::ranges::to, и конвертация стала лаконичнее:for (auto part : csv | split(',')) {
std::cout << std::ranges::to<std::string>(part) << "\n";
}views::split возвращает под-диапазоны, а не строки — явное преобразование обязательно в обоих стандартах.std::vector<int> data = {1, 2, 3, 4, 5, 6, 7};
for (auto chunk : data | views::chunk(3)) {
for (int x : chunk) std::cout << x << " ";
std::cout << "\n";
} /
/ 1 2 3
// 4 5 6
// 7Группирует соседние элементы, пока выполняется предикат между двумя соседями.
std::vector<int> v = {1, 1, 2, 3, 3, 3, 4, 4};
// Группируем подряд идущие равные элементы
for (auto group : v | views::chunk_by(std::equal_to{})) {
for (int x : group) std::cout << x << " ";
std::cout << "| ";
} /
/ 1 1 | 2 | 3 3 3 | 4 4 |
// Вариант с std::equal_to<>{} — лаконичнее:
for (auto group : v | chunk_by(std::equal_to<>{})) { ... }📍Навигация: Вакансии • Задачи • Собесы
Библиотека C/C++ разработчика
#константная_правильность
Please open Telegram to view this post
VIEW IN TELEGRAM
👍10
😎 Топ-вакансий для C++ разработчиков за неделю
C++ red team developer — от 180 000 и до 450 000 ₽
Офис (Санкт-Петербург)
C++ разработчик (CHYT) — Гибрид (Москва, Санкт-Петербург, Минск, Белград)
Senior Rendering engineer C++ в 3D Карту — от 350 000 и до 400 000 ₽ Удалёнка/Гибрид (Санкт-Петербург, Москва)
✍️ Еще больше топовых вакансий — в нашем канале C++ jobs
📍Навигация: Вакансии • Задачи • Собесы
Библиотека C/C++ разработчика
#буст
C++ red team developer — от 180 000 и до 450 000 ₽
Офис (Санкт-Петербург)
C++ разработчик (CHYT) — Гибрид (Москва, Санкт-Петербург, Минск, Белград)
Senior Rendering engineer C++ в 3D Карту — от 350 000 и до 400 000 ₽ Удалёнка/Гибрид (Санкт-Петербург, Москва)
✍️ Еще больше топовых вакансий — в нашем канале C++ jobs
📍Навигация: Вакансии • Задачи • Собесы
Библиотека C/C++ разработчика
#буст
👍1😁1
🎤 Ваши знания по ИИ-агентам + наша аудитория в 1 млн человек = профит
Мы в Proglib активно качаем тему ИИ-агентов. Если вы в теме, то у нас есть предложение 👇
Что с нас?
- Огромный охват: пропиарим ваши соцсети и продукты на 1 000 000+ айтишников.
- Личный бренд: станете узнаваемым экспертом в самой горячей нише 2026 года.
- Никакой рутины: наши редакторы сами упакуют ваши мысли в крутые посты.
Что с вас?
Любой экспертный контент по ИИ-агентам: кейсы из прода, шпаргалки, статьи, наработки по стеку (LangGraph, CrewAI, AutoGen и др.) или просто мысли по архитектуре.
👉 Стать экспертом и заявить о себе
Мы в Proglib активно качаем тему ИИ-агентов. Если вы в теме, то у нас есть предложение 👇
Что с нас?
- Огромный охват: пропиарим ваши соцсети и продукты на 1 000 000+ айтишников.
- Личный бренд: станете узнаваемым экспертом в самой горячей нише 2026 года.
- Никакой рутины: наши редакторы сами упакуют ваши мысли в крутые посты.
Что с вас?
Любой экспертный контент по ИИ-агентам: кейсы из прода, шпаргалки, статьи, наработки по стеку (LangGraph, CrewAI, AutoGen и др.) или просто мысли по архитектуре.
👉 Стать экспертом и заявить о себе
😁1
По умолчанию, когда вы нажимаете
F11 (Step Into) в Visual Studio, отладчик проваливается в каждую функцию — включая стандартную библиотеку, runtime и сторонний код?Функция
Just My Code решает эту проблему. При включении отладчик автоматически перешагивает через код, который не принадлежит вашему проекту — будь то STL, CRT или любые внешние библиотеки.Tools → Options → Debugging → General → Enable Just My Code
#include <vector>
#include <algorithm>
#include <iostream>
int doubleValue(int x) {
return x * 2; // ← ВАШ код
}
int main() {
std::vector<int> v = {3, 1, 4, 1, 5};
// F11 здесь без JMC → провалится в std::sort
std::sort(v.begin(), v.end());
// F11 здесь без JMC → провалится в std::transform
std::transform(v.begin(), v.end(), v.begin(), doubleValue);
return 0;
}
Без JMC: F11 на
std::sort уводит вас в дебри introsort внутри STL.С JMC: отладчик перепрыгивает sort и останавливается на следующей вашей строке.
📍Навигация: Вакансии • Задачи • Собесы
Библиотека C/C++ разработчика
#буст
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥11👍1
Ranges умеют генерировать их на лету — без выделения памяти под вектор. Разберём два главных генератора.Генерирует последовательность чисел в полуоткрытом интервале [start, end):
// Числа от 0 до 9
for (int i : views::iota(0, 10)) {
std::cout << i << " "; // 0 1 2 3 4 5 6 7 8 9
}
Можно передать только одно значение — получится бесконечная последовательность:
auto naturals = views::iota(1); // 1, 2, 3, 4, ...
auto first_10 = naturals | views::take(10);
views::take.До появления
views::enumerate пару (индекс, значение) получали через views::zip с iota:std::vector<std::string> fruits = {"яблоко", "банан", "вишня"};
for (auto [i, fruit] : views::zip(views::iota(0), fruits)) {
std::cout << i << ": " << fruit << "\n";
}
// 0: яблоко
// 1: банан
// 2: вишняВ C++23 для этого есть
views::enumerate — но zip + iota по-прежнему работает и даёт понять, как устроена индексация изнутри.Генерирует бесконечный поток из одного и того же значения:
for (int x : views::repeat(0) | views::take(5)) {
std::cout << x << " "; // 0 0 0 0 0
}Или сразу с ограничением — передаём второй аргумент:
for (auto s : views::repeat("hello", 3)) {
std::cout << s << " "; // hello hello hello
}views::take не нужен.📍Навигация: Вакансии • Задачи • Собесы
Библиотека C/C++ разработчика
#константная_правильность
Please open Telegram to view this post
VIEW IN TELEGRAM
🥰3🤩1