Библиотека C/C++ разработчика | cpp, boost, qt
19.5K subscribers
1.98K photos
62 videos
16 files
4.23K links
Все самое полезное для плюсовика и сишника в одном канале.

По рекламе: @proglib_adv

Учиться у нас: https://proglib.io/w/d6cd2932

Для обратной связи: @proglibrary_feeedback_bot

РКН: https://gosuslugi.ru/snet/67a5bac324c8ba6dcaa1ad17
Download Telegram
🤟 Путь к мечте продолжается

Два года российские нейрохирурги отказывали мне в операции, запугивая
последствиями. В итоге поехал в Казахстан — сделали две паллидотомии,
которые «нельзя было делать». Речь на месте, здоровье улучшается.
Параллельно учу C++ и ищу работу. История о том, как не сдаваться, когда
система говорит «нет».

👉 Продолжение...

📍Навигация: ВакансииЗадачиСобесы

Библиотека C/C++ разработчика

#буст
6👍4🙏3
⚡️ От SFINAE к Concepts: эволюция метапрограммирования

Compile-time магия прошла долгий путь от криптографического SFINAE к читаемым concepts.

Эра 1: Классический SFINAE (C++98)

template<typename T>
typename std::enable_if<std::is_integral<T>::value, T>::type
increment(T value) {
return value + 1;
}
// Что происходит? Кто знает...


Эра 2: Type traits (C++11/14)

template<typename T>
std::enable_if_t<std::is_integral_v<T>, T>
increment(T value) {
return value + 1;
}
// Чуть лучше с _t и _v суффиксами


Эра 3: if constexpr (C++17)

template<typename T>
T process(T value) {
if constexpr (std::is_integral_v<T>) {
return value + 1;
} else if constexpr (std::is_floating_point_v<T>) {
return value * 1.1;
} else {
return value;
}
}
// Читается как обычный код!


Эра 4: Concepts (C++20)

template<std::integral T>
T increment(T value) {
return value + 1;
}

// Или
auto increment(std::integral auto value) {
return value + 1;
}
// Красота и понятность!


😏 А какой подход вам больше нравится? Напиши в комментариях!

📍Навигация: ВакансииЗадачиСобесы

Библиотека C/C++ разработчика

#константная_правильность
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥102👍1😁1
Перевод: Правительство США рассекретило PoC (Proof of Concept)

📍Навигация: ВакансииЗадачиСобесы

Библиотека C/C++ разработчика

#развлекалово
😁103
This media is not supported in your browser
VIEW IN TELEGRAM
AI-агенты: когда точность архитектуры важнее магии промптов

Мы смотрим на ИИ как на инженерную задачу. Мы учим строить автономные системы с детерминированной логикой, контролем ресурсов и предсказуемым поведением.

Основные темы:

управление состояниями в LangGraph для проектирования надёжных стейт-машин;
работа с данными через RAG-системы на базе векторных хранилищ;
автоматизация и мониторинг через связку n8n и LangSmith для полного аудита;
безопасность системы с внедрением Guardrails для защиты от некорректных запросов.

Постройте масштабируемую AI-систему с инженерным подходом.

Записаться на курс
😁21
🐥 Почему std::chrono::duration не хранит единицы измерения?

duration<int, std::milli> не хранит информацию о миллисекундах. На самом деле это compile-time магия.

Как это работает:

duration — это просто обёртка над числом. Шаблонный параметр std::milli (он же std::ratio<1, 1000>) существует только на этапе компиляции.

duration<int64_t, std::milli> ms(1000);
// В памяти: просто int64_t со значением 1000
// Информации "это миллисекунды" в рантайме НЕТ


🍴 Механизм конверсии:

Когда вы пишете duration_cast<seconds>(ms), компилятор вычисляет 1000 / 1000 = 1 на этапе компиляции через механизм std::ratio. Никаких делений в рантайме при конверсии целых периодов.
Вывод: Zero-overhead абстракция. В release-сборке duration<int, milli> — это буквально int с type safety. Но осторожно: duration_cast может обрезать дробную часть при конверсии вниз.


📍Навигация: ВакансииЗадачиСобесы

Библиотека C/C++ разработчика

#под_капотом
Please open Telegram to view this post
VIEW IN TELEGRAM
👍7
🎅 Секретный Санта для айтишников от Proglib.academy

Весь этот год команда Академии запускала курсы для айтишников. А под Новый год мы запускаем новый курс по ИИ-агентам и ставим под ёлку самый свежий стек 2025 года и обучение проектированию автономных нейросетевых экосистем — от LLM и ReAct-циклов до мультиагентных систем, LangGraph, AutoGen и продакшн-практик.

🎁 Хотим дарить подарки и приглашаем вас поучаствовать в конкурсе:

1️⃣ Упомяните курс Академии у себя в блоге.
2️⃣ Пришлите скрин сюда.
3️⃣ Получите секретный промокод на 10 000 ₽ при оплате любого курса.

Подходит всё — соцсети, блоги, Telegram-каналы от 300 подписчиков и более.

🎄 Акция действует до Нового года.

Win-win, всё как мы любим!
😁1
📕 Написал код на С++23, а он запустился на Windows 95...

Представь: пишешь код с модулями C++23 в Visual Studio 2026, жмёшь компиляцию... И получаешь exe для Windows 95.


Подробный разбор нестандартного подхода к ретро-программированию с использованием всех благ современного C++.

Основные шаги:

• компиляция только в 32-bit x86 с отключёнными исключениями и STL
• использование линкера от Visual C++ 6.0 для финальной сборки
• создание минимальной реализации std с базовыми контейнерами

Фокус на практическом применении — портирование проектов LDL и движка Arcanum на C++23 с сохранением поддержки Windows 98.

Актуально для разработчиков, которые создают новые игры, моды и улучшения для старых систем в рамках комьюнити вроде Old-Games.ru.

Главное преимущество — один и тот же код работает и на современной системе (для отладки), и на ретро-железе (для финального запуска).

👉 Статья

Навигация: ВакансииЗадачиСобесы

Библиотека C/C++ разработчика

#свежак
1🔥8👾7👍31🥱1
WANTED: C++ ЭКСПЕРТ

Обвиняется в прямом управлении памятью и знании тёмных углов стандарта. Если ты выжил в мире плюсов и готов учить этому других — мы тебя ищем.

Приметы:

— в совершенстве владеет C/C++ (понимает логику Go или Java);
— умеет писать производительный и безопасный код;
— обладает терпением и талантом наставника;
— хочет выйти на большую аудиторию Proglib.

Награда:

— вознаграждение за твой вклад в обучение;
— статус признанного эксперта в комьюнити;
— поддержка твоего личного бренда.

Сдаться добровольно

P.S. Знаешь «плюсовика», который знает слишком много? Сдай его нам.
🔥1😁1
🐸 Подборка вакансий для C++-разработчиков за неделю

C++/Qt/QML-разработчик под Android (Транспорт) — от 250 000 ₽ Удалёнка

Senior C++ engineer («Разработка ядер рекламной платформы»)

C++ Developer (Real-Time Audio Processing) — от 288 000 и до 320 000₽ Удалёнка

Senior С++ Backend Developer (Поиск) — от 350 000 ₽ Удалёнка

Разработчик графических приложений Qt/С++ — от 150 000 и до 250 000 ₽ Удалёнка

System С++ developer — Офис (Москва)

Библиотека C/C++ разработчика
👍2🤩1
Литералы времени: пишите код, который читается

C++14 добавил user-defined literals для chrono. Это превращает магические числа в self-documenting код.

До:


std::this_thread::sleep_for(std::chrono::milliseconds(500));
std::chrono::seconds timeout(30);


После:

using namespace std::chrono_literals;

std::this_thread::sleep_for(500ms);
auto timeout = 30s;
auto delay = 1.5min; // 90000ms внутри


Полный список:

auto ns = 100ns;   // nanoseconds
auto us = 100us; // microseconds
auto ms = 100ms; // milliseconds
auto s = 100s; // seconds
auto min = 100min; // minutes
auto h = 100h; // hours


❗️Важно: Дробные литералы (1.5s) возвращают duration<double>, а не duration<int64_t>. Учитывайте при строгой типизации.

Добавьте using namespace std::chrono_literals; в каждый файл с chrono — читаемость кода скажет спасибо!

📍Навигация: ВакансииЗадачиСобесы

Библиотека C/C++ разработчика

#под_капотом
Please open Telegram to view this post
VIEW IN TELEGRAM
👍6
🧩 Задача на выходные: оптимизируй код

Код работает, но выглядит... не очень. С++20 даёт нам крутые инструменты для упрощения.

#include <vector>
#include <algorithm>
#include <iostream>

std::vector<int> filterAndTransform(const std::vector<int>& input) {
std::vector<int> filtered;
for (const auto& val : input) {
if (val % 2 == 0) {
filtered.push_back(val);
}
}

std::vector<int> result;
for (const auto& val : filtered) {
result.push_back(val * val);
}

return result;
}


Задача: Перепиши эту функцию используя ranges (C++20).

Бонус: Можно ли избежать промежуточных копирований?

✏️ Покажи свою версию в комментариях.


📍Навигация: ВакансииЗадачиСобесы

Библиотека C/C++ разработчика

#междусобойчик