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

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

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

Наши каналы: https://yangx.top/proglibrary/9197

РКН: https://gosuslugi.ru/snet/67a5bac324c8ba6dcaa1ad17
加入频道
Представьте, что вы за час можете научиться чему угодно — что бы это было?
#интерактив
std::tie

std::tie — это функция, которая создает кортеж ссылок на lvalue из своих аргументов или экземпляров std::ignore.

Она может использоваться для распаковки кортежей или пары значений в отдельные переменные. Например, если у вас есть функция, которая возвращает std::pair или std::tuple, вы можете использовать std::tie, чтобы присвоить значения этого кортежа отдельным переменным.

В этом примере мы используем std::tie для распаковки результата вызова set_of_s.insert(value) в две переменные: итератор iter и логическую переменную inserted.
Это позволяет нам проверить, было ли значение успешно вставлено в набор.
#код
«Библиотека программиста» в поиске контент-менеджера для ведения телеграм-каналов

Ищем человека, который грамотно пишет, разбирается в контенте и в одной из этих трех тем:
👉Data Science
👉Frontend
👉мобильная разработка

Мы предлагаем частичную занятость и полностью удаленный формат работы — можно совмещать с основной и находиться в любом месте🌴

Подробнее о вакансии и форма для отклика — по ссылке.

Ждем вас в команде!
В чем разница между git fetch и git pull?

Разница между этими командами заключается в том, что когда вы используете команду git fetch, Git извлекает последние изменения из удаленного репозитория в ваш локальный репозиторий, но оставляет эти изменения в отдельной ветке git origin.

А команда git pull извлекает и интегрирует (скачивает и сливает) последние изменения из удаленного репозитория в вашу текущую ветку работы.
execution policy для параллельных алгоритмов

Execution policy в C++ — это новшество, введенное в стандарте языка C++17. Это механизм, который позволяет выбрать, как именно должны выполняться алгоритмы в стандартной библиотеке: последовательно или параллельно.

Существуют три варианта execution policy:

— seq: выполняет алгоритм последовательно.
— par: выполняет алгоритм параллельно, используя все доступные ядра процессора.
— par_unseq: выполняет алгоритм параллельно и может использовать неупорядоченное исполнение.

Execution policy может быть использован в комбинации с многими алгоритмами в стандартной библиотеке, такими как std::for_each, std::transform, std::reduce и другими. Например, код выше выполняет алгоритм std::for_each параллельно.
Задача

Найти среднее арифметическое в трех рядах.

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

Теперь подумаем, какие переменные нам понадобятся:

Переменная summa — для суммы чисел каждого ряда;
Переменная average — для среднего арифметического каждого ряда;
Переменная number — обычное число которое мы будем постоянно прибавлять;
Переменные i и j — для циклов, перпенные у нас будут локальные, т.е. использоваться и объявляться в цикле.
#вопросы_с_собеседований
Внутри STL: строка

Вы можете подумать, что std::string (и все его друзья в семействе std::basic_string) внутри в основном представляют собой вектор символов. Но строки организованы по-другому из-за определенных оптимизаций, разрешенных для строк, но не для векторов.

Читать статью
«Библиотека программиста» запустила два новых канала для C++ разработчиков и тех, кто хочет ими стать👨‍🏫

В них мы:
🔸тренируемся на практических задачах
🔸отвечаем на популярные вопросы с собеседований
🔸проверяем свои знания

Подписывайтесь:
👉Библиотека собеса по C++ — тут мы готовимся к интервью
👉Библиотека задач по C++ — тут решаем задачи, проходим тесты и изучаем код
Dependency Injection

Dependency Injection (DI) — это паттерн проектирования, который позволяет управлять зависимостями между объектами. Он помогает разделить создание объектов от их использования и обеспечить более гибкую и тестируемую архитектуру программы.

В DI объекты получают свои зависимости не напрямую, а через внешний источник, который их предоставляет. Этот источник называется контейнером внедрения зависимостей. Контейнер отвечает за создание и управление зависимостями, а объекты получают их через конструкторы, методы или свойства.
#код
Очередной #дайджест по С++:

✍️ Визуализируйте расширение макроса для C++
Эта функция дает значительные преимущества, позволяя вам понимать и анализировать сложные многоуровневые расширения макросов шаг за шагом.

✍️ soagen: генератор и библиотека структуры массивов
Обзор soagen — новый генератор структуры массивов и библиотека для C++17 и более поздних версий.

✍️ Измерение производительности подсистемы памяти
Обширный материал об оптимизации.

✍️ Юникод сложнее, чем вы думаете
Unicode — это тема, которую многие разработчики часто упускают из виду. Существует много путаницы и неправильных ожиданий относительно того, что такое Unicode, и какие рекомендации следует соблюдать при работе со строками, которые могут содержать символы за пределами диапазона ASCII.
Какой сертификат вы бы посоветовали получить?
#интерактив
Использование Boost

Если ваш проект открыт для поддержки библиотеки, рассмотрите возможность использования boost::algorithm::join алгоритм. Он объединяет все элементы в указанном списке в строку, где сегменты объединяются заданным разделителем.

Другие способы преобразования вектора в строку можно найти здесь.
Весь август бесплатный IT-интенсив про алгоритмы и структуры данных

👀 Ведущие эксперты из крупных IT-компаний поделятся опытом успешного прохождения собеседований на позицию разработчика. А также расскажут простым языком о NP-трудных задачах и графах.

Регистрируйтесь по ссылке

😎На вебинарах вас ждет много практики и интерактива!

Программа интенсива:

🗓️ 14 августа, «NP-трудные задачи: почему их плохо решают».
🎙️Спикер: Дмитрий Коротенко, ML specialist at Yandex, Ex BusDev at Alfa Bank.

🗓️ 22 августа, «Графы: алгоритмы и структуры данных на Python».
🎙️Спикер: Иван Потапов, Staff machine learning engineer at Sharechat.

🗓️ 29 августа, «Собеседование на разработчика: разбор задач и ошибок».
🎙️Спикер: Алексей Бочкарев, Engineering Manager at Meta*

Зарегистрироваться и ознакомится с подробной программой можно по ссылке: https://proglib.io/w/62ce6c0e

До встречи на вебинарах!!

*Компания Meta признана в РФ экстремистской и запрещена
Что случится, если exception выйдет за пределы потока?

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

Чтобы избежать данной ситуации, необходимо обернуть код, где может возникнуть исключение, в try-catch блок на том же уровне, что и поток, с которым он связан.
#вопросы_с_собеседований
std::hash

Это структура шаблонного класса, определенная в заголовочном файле. Она предоставляет хеш-функцию для хэширования различных типов данных, включая встроенные и пользовательские.

std::hash используется, например, в ассоциативных контейнерах, таких как std::unordered_map и std::unordered_set, для быстрого доступа к элементам по ключу.

Для пользовательского типа данных требуется явная специализация структуры std::hash для корректной работы хэширования.
#код
Сколько времени в рабочий день тратите на разработку?
#интерактив
Опыт создания клипа на Unreal Engine 5.1 с метахьюманом, ветром и багами

Обширный материал со ссылками на обучающие источники.

Читать статью
Очередной #дайджест статей по С++:

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

🤖 Определение области коллизии
Как можно вычислить точки контакта между двумя объектами для правильного расчёта центра приложенных сил?

🤖 Seastar как платформа для опорной сети 5G и краткое сравнение с Boost.Asio, userver и другими
Сравнение Seastar, mTCP, Boost.Asio, userver и ACE, а также почему примитивы синхронизации — это плохо.

🤖 Выжимаем ATtiny10, практическое применение

🤖 Buran Motion Planning Framework
В данной статье сделан обзор на OpenSource фреймворк планирования движения BMPF.
This media is not supported in your browser
VIEW IN TELEGRAM
Основные алгоритмы на графах

В статье рассмотрены основные алгоритмы на графах и их реализацию на C++.

Рассматриваемые алгоритмы:
Обход графа в ширину (Поиск в ширину) aka BFS | Breadth First Search
Обход графа в глубину (Поиск в глубину) aka DFS | Depth First Search
Алгоритм Дейкстры
Алгоритм Флойда-Уоршелла
Алгоритм Прима

Смотреть статью