🏖️ Подборка вакансий для C++-разработчиков за неделю
Разработчик C++ — от 250 000 и до 400 000 ₽ Удалёнка
Team Lead C++ (Social Core) — от 300 000 ₽ Удалёнка
Senior C++ Developer — от 380 000 и до 430 000 ₽ Удалёнка
Senior Embedded-разработчик / программист микроконтроллеров — от 300 000 ₽ Офис (Москва)
C++-разработчик (Новости) — от 270 000 и до 370 000 ₽ Удалёнка
Библиотека C/C++ разработчика
Разработчик C++ — от 250 000 и до 400 000 ₽ Удалёнка
Team Lead C++ (Social Core) — от 300 000 ₽ Удалёнка
Senior C++ Developer — от 380 000 и до 430 000 ₽ Удалёнка
Senior Embedded-разработчик / программист микроконтроллеров — от 300 000 ₽ Офис (Москва)
C++-разработчик (Новости) — от 270 000 и до 370 000 ₽ Удалёнка
Библиотека C/C++ разработчика
💭 Race conditions в атомарных операциях - одна из самых коварных проблем. Разбираемся с memory ordering.
Проблема: Неопределенное поведение при concurrent доступе
// ❌ ОПАСНО: data race!
std::atomic<bool> ready{false};
int data = 0;
// Thread 1
data = 42;
ready.store(true); // неопределенный ordering!
// Thread 2
if (ready.load()) {
process(data); // может быть 0 или 42!
}
Решение: Explicit memory ordering
// ✅ ПРАВИЛЬНО: используем memory_order
std::atomic<bool> ready{false};
int data = 0;
// Thread 1
data = 42;
ready.store(true, std::memory_order_release); // освобождаем
// Thread 2
if (ready.load(std::memory_order_acquire)) { // захватываем
process(data); // гарантированно 42!
}
⚠️ Частые ошибки:
• Использование memory_order_relaxed везде
• Забывание про acquire-release семантику
• Смешивание атомарных и неатомарных операций
Библиотека C/C++ разработчика #буст
Please open Telegram to view this post
VIEW IN TELEGRAM
🤔4👍2
🤔 Зачем вообще понимать, как работает ML?
Сейчас многие просто запускают модельку в sklearn — и радуются точности 0.92.
Машинное обучение — это система, которую можно понять.
Если знаешь, что делает градиентный спуск, зачем нужен бустинг и как дерево принимает решения — ты не просто «запускаешь», ты управляешь моделью.
👉 Мы сделали курс, чтобы в это было реально въехать:
— без сложных формул;
— с интуитивными объяснениями;
— от простого к сложному.
Если хочешь перейти от «гуглю код» к «понимаю, как это работает» — ты по адресу!
❗Стартуем в сентябре — бронируй место на курсе уже сейчас
Сейчас многие просто запускают модельку в sklearn — и радуются точности 0.92.
Вроде всё работает… но почему?
А когда сломается — что делать?
Машинное обучение — это система, которую можно понять.
Если знаешь, что делает градиентный спуск, зачем нужен бустинг и как дерево принимает решения — ты не просто «запускаешь», ты управляешь моделью.
👉 Мы сделали курс, чтобы в это было реально въехать:
— без сложных формул;
— с интуитивными объяснениями;
— от простого к сложному.
Если хочешь перейти от «гуглю код» к «понимаю, как это работает» — ты по адресу!
❗Стартуем в сентябре — бронируй место на курсе уже сейчас
❤2🥱2😁1
👾 Clang получает режим усиленной безопасности
Разработчики
🏖️ Новый режим одной командой активирует целый набор защитных механизмов:
• Инициализация переменных нулями
• Защита стека и от переполнений
• Рандомизация адресов
• Усиленные проверки библиотек
• Дополнительные предупреждения
Проблема: разрозненность опций безопасности в C/C++. Многие разработчики просто не знают о их существовании или забывают включать.
Решение: единый флаг, который «из коробки» делает код безопаснее.
Конечно, это костыли для языков 70-80х годов, но лучше поздно чем никогда.
👉 Заметка
Библиотека C/C++ разработчика #буст
Разработчики
Clang
обсуждают добавление флага -fhardened
по аналогии с GCC 14
. 🏖️ Новый режим одной командой активирует целый набор защитных механизмов:
• Инициализация переменных нулями
• Защита стека и от переполнений
• Рандомизация адресов
• Усиленные проверки библиотек
• Дополнительные предупреждения
Проблема: разрозненность опций безопасности в C/C++. Многие разработчики просто не знают о их существовании или забывают включать.
Решение: единый флаг, который «из коробки» делает код безопаснее.
Конечно, это костыли для языков 70-80х годов, но лучше поздно чем никогда.
👉 Заметка
Библиотека C/C++ разработчика #буст
Часто при написании операторов присваивания или swap-функций приходится сохранять старое значение, заменяя его новым. Код получается многословным и подверженным ошибкам.
std::exchange
атомарно заменяет значение переменной и возвращает старое значение — всё в одной строке.T old_value = obj;
obj = new_value;
return old_value;
return std::exchange(obj, new_value);
Код становится более читаемым, безопасным и выразительным. Особенно полезно в RAII-классах и при работе с умными указателями.
Библиотека C/C++ разработчика #буст
Please open Telegram to view this post
VIEW IN TELEGRAM
👍13