ch
Feedback
C++ geek

C++ geek

前往频道在 Telegram

Учим C/C++ на примерах

显示更多
3 611
订阅者
+124 小时
-87
-4030
吸引订阅者
六月 '26
六月 '26
+3
在0个频道中
五月 '26
+28
在0个频道中
Get PRO
四月 '26
+25
在0个频道中
Get PRO
三月 '26
+33
在0个频道中
Get PRO
二月 '26
+47
在0个频道中
Get PRO
一月 '26
+57
在1个频道中
Get PRO
十二月 '25
+48
在0个频道中
Get PRO
十一月 '25
+120
在31个频道中
Get PRO
十月 '25
+71
在0个频道中
Get PRO
九月 '25
+130
在37个频道中
Get PRO
八月 '25
+78
在1个频道中
Get PRO
七月 '25
+102
在28个频道中
Get PRO
六月 '25
+115
在20个频道中
Get PRO
五月 '25
+122
在44个频道中
Get PRO
四月 '25
+145
在37个频道中
Get PRO
三月 '25
+131
在38个频道中
Get PRO
二月 '25
+140
在31个频道中
Get PRO
一月 '25
+149
在33个频道中
Get PRO
十二月 '24
+141
在35个频道中
Get PRO
十一月 '24
+133
在33个频道中
Get PRO
十月 '24
+160
在30个频道中
Get PRO
九月 '24
+300
在29个频道中
Get PRO
八月 '24
+125
在18个频道中
Get PRO
七月 '24
+102
在0个频道中
Get PRO
六月 '24
+120
在24个频道中
Get PRO
五月 '24
+124
在19个频道中
Get PRO
四月 '24
+131
在0个频道中
Get PRO
三月 '24
+150
在21个频道中
Get PRO
二月 '24
+130
在18个频道中
Get PRO
一月 '24
+208
在24个频道中
Get PRO
十二月 '23
+161
在24个频道中
Get PRO
十一月 '23
+111
在18个频道中
Get PRO
十月 '23
+179
在18个频道中
Get PRO
九月 '23
+179
在0个频道中
Get PRO
八月 '23
+106
在0个频道中
Get PRO
七月 '23
+158
在0个频道中
Get PRO
六月 '23
+120
在0个频道中
Get PRO
五月 '23
+129
在0个频道中
Get PRO
四月 '23
+113
在0个频道中
Get PRO
三月 '23
+44
在0个频道中
Get PRO
二月 '23
+68
在0个频道中
Get PRO
一月 '23
+128
在0个频道中
Get PRO
十二月 '22
+144
在0个频道中
Get PRO
十一月 '22
+139
在0个频道中
Get PRO
十月 '22
+226
在0个频道中
Get PRO
九月 '22
+1 184
在0个频道中
日期
订阅者增长
提及
频道
04 六月0
03 六月+1
02 六月+2
01 六月0
频道帖子
🚀 Сегодня я покажу вам простой, но очень полезный приём в C++: как элегантно управлять временем жизни ресурса с помощью std::unique_ptr и кастомного deleter'а. 📌 Задача: у нас есть не-C++ ресурс, например, FILE* из stdio.h. Мы хотим, чтобы он автоматически закрывался, как только выходит из области видимости. Вместо ручного вызова fclose, используем std::unique_ptr с кастомным deleter'ом:

#include <memory>
#include <cstdio>

int main() {
    // Кастомный deleter для FILE*
    auto fileDeleter = [](FILE* f) {
        if (f) {
            std::puts("Файл закрывается автоматически!");
            std::fclose(f);
        }
    };

    // Умный указатель с кастомным deleter'ом
    std::unique_ptr<FILE, decltype(fileDeleter)> file(std::fopen("data.txt", "r"), fileDeleter);

    if (!file) {
        std::perror("Не удалось открыть файл");
        return 1;
    }

    // Файл будет автоматически закрыт в конце блока main()
}
💡 Такой подход безопаснее, чем fopen/fclose, особенно в реальных проектах с множеством return'ов и исключениями. А главное — код остаётся чистым и идиоматичным. 🔥 А вы используете unique_ptr с кастомным deleter’ом в своём коде? Поделитесь, для чего вы его применяли! ➡️ @cpp_geek

2
🚀 Подборка полезных IT каналов в Max Системное администрирование, DevOps 📌 https://max.ru/i_odmin Все для системного администратора https://max.ru/bash_srv Bash Советы https://max.ru/sysadminof Книги для админов, полезные материалы https://max.ru/i_odmin_book Библиотека Системного Администратора https://max.ru/i_devops DevOps: Пишем о Docker, Kubernetes и др. https://max.ru/tipsysdmin Типичный Сисадмин Excel лайфхак 📌 https://t.me/Excel_lifehack Excel лайфхак 1C разработка 📌 https://max.ru/odin1c_rus Cтатьи, курсы, советы, шаблоны кода 1С Программирование C++📌 https://max.ru/cpp_lib Библиотека C/C++ разработчика Программирование Go📌 https://max.ru/golang_lib Библиотека Go (Golang) разработчика Программирование React📌 https://max.ru/react_lib React Программирование Python 📌 https://max.ru/python_of Python академия. https://max.ru/BookPython Библиотека Python разработчика Java разработка 📌 https://max.ru/bookjava Библиотека Java разработчика GitHub Сообщество 📌 https://max.ru/githublib Интересное из GitHub Базы данных (Data Base) 📌 https://max.ru/database_info Все про базы данных Фронтенд разработка 📌 https://max.ru/frontend_1 Подборки для frontend разработчиков Библиотеки 📌 https://max.ru/programmist_of Книги по программированию https://max.ru/proglb Библиотека программиста https://max.ru/bfbook Книги для программистов Программирование 📌 https://max.ru/bookflow Лекции, видеоуроки, доклады с IT конференций https://max.ru/itmozg Программисты, дизайнеры, новости из мира IT https://max.ru/php_lib Библиотека PHP программиста 👨🏼‍💻👩‍💻 Шутки программистов 📌 https://max.ru/itumor Шутки программистов Защита, взлом, безопасность 📌 https://max.ru/thehaking Канал о кибербезопасности https://max.ru/xakkep_1 Хакер Free Книги, статьи для дизайнеров 📌 https://max.ru/odesigners Статьи, книги для дизайнеров Математика 📌 https://max.ru/Pomatematike Канал по математике https://max.ru/phismat_1 Обучающие видео, книги по Физике и Математике Вакансии 📌 https://max.ru/progjob Вакансии в IT Мир технологий 📌 https://max.ru/mir_teh Канал для любознательных Бонус 📌 https://max.ru/piterspb_78 Свежие новости Санкт-Петербурга https://max.ru/mockva_life Свежие новости Москвы https://max.ru/piterspb Питер Новости: Санкт-Петербург / СПБ / ДТП
303
3
🔧 Что делать, если std::sort тормозит? Привет! Сегодня хочу поделиться с вами одной типичной ситуацией, с которой сталкивался не раз — сортировка больших контейнеров через std::sort, которая неожиданно начинает тормозить. Вызываешь вроде обычную сортировку, а работает медленно. Почему так? 🔍 Проблема — не std::sort, а компаратор! В 90% случаев проблема не в std::sort, а в лямбде или компараторе, который вы передаёте. Особенно если он: 1. Вызывает копирование: вы сравниваете по значениям, а не по ссылке. 2. Делает что-то тяжёлое внутри: например, вызывает метод, делает std::string копию, обращается к БД (да, и такое видел!). 3. Некеширует результат: например, каждый раз считает длину строки. ✅ Как ускорить сортировку: - Передавайте данные по ссылке, особенно если у вас вектор структур: std::sort(vec.begin(), vec.end(), [](const MyStruct& a, const MyStruct& b) { return a.key < b.key; }); - Если у вас есть вычисление ключа — используйте схему "decorate-sort-undecorate": std::vector<std::pair<int, size_t>> temp; for (size_t i = 0; i < vec.size(); ++i) temp.emplace_back(compute_key(vec[i]), i); std::sort(temp.begin(), temp.end()); std::vector<MyStruct> result; for (const auto& [_, i] : temp) result.push_back(vec[i]); 🧠 Мораль: Если std::sort "медленный", не спешите винить алгоритм. Лучше проверьте, что вы передаёте ему на вход. ➡️ @cpp_geek
541
4
🔥 Ловим баги в C++ на лету с помощью AddressSanitizer (ASan) Если valgrind — это медленный, но подробный детектив, то ASan — это охрана, которая ловит баги прямо во время исполнения. Быстро, точно, удобно. 💡 Что такое ASan? Это часть компилятора (clang или gcc), которая вставляет дополнительные проверки в бинарник. Работает во время запуска, ловит: - выход за границы массива, - use-after-free, - double free, - утечки памяти (с флагом LeakSanitizer). 👨‍💻 Пример: // asan_example.cpp #include <iostream> int main() { int* arr = new int[5]; arr[10] = 42; // выход за границу delete[] arr; return 0; } ⚙️ Компиляция с ASan: g++ -fsanitize=address -g asan_example.cpp -o app 🚀 Запуск: ./app 📄 Результат: ==12345==ERROR: AddressSanitizer: heap-buffer-overflow on address 0x602000000050 READ of size 4 at 0x602000000050 thread T0 #0 0x... in main asan_example.cpp:6 📌 Плюсы ASan: - Мгновенная обратная связь; - Прост в использовании; - Отлично работает с CI (GitHub Actions, GitLab CI и т.д.); - Поддерживает LeakSanitizer (-fsanitize=leak). 📉 Минусы: - Увеличивает размер бинарника; - Иногда мешает оптимизациям; - Не ловит всё (например, утечки в сторонних lib без debug info). 🔧 Совет: Запускай тесты с -fsanitize=address в debug-сборках. Это бесплатно и спасает от кучи головной боли в будущем. 🧵 Используешь ли ты ASan в своих проектах? Или только valgrind? Пиши в комментах👇 ➡️ @cpp_geek
706
5
🔧 Как ловить утечки памяти в C++ за 5 минут Инструмент — valgrind. Когда пишем на C++, особенно без smart pointers, утечки памяти — обычное дело. Часто их даже не видно. А valgrind — это наш рентген. 👣 Быстрый гайд: 1. Установи valgrind: sudo apt install valgrind 2. Собери проект с отладочной информацией: g++ -g main.cpp -o app 3. Запусти под valgrind: valgrind ./app 4. И читай отчёт: ==12345== 10 bytes in 1 blocks are definitely lost in loss record 1 of 1 💡 Фишка: Добавь --leak-check=full и --track-origins=yes — получишь больше деталей, где именно утечка: valgrind --leak-check=full --track-origins=yes ./app ➡️ @cpp_geek
743
6
🎯 Как избежать макросов в C++ и остаться довольным Сегодня я покажу вам, как можно избавиться от макросов в C++ и заменить и
🎯 Как избежать макросов в C++ и остаться довольным Сегодня я покажу вам, как можно избавиться от макросов в C++ и заменить их на более безопасные и выразительные конструкции. 🔴 Проблема: #define — это зло. Они не уважают область видимости, не отлаживаются нормально, не подчиняются типам и могут вызвать кучу проблем, особенно в больших проектах. 👉 Вместо #define PI 3.14 Используем: constexpr double PI = 3.14; 👉 Вместо #define SQUARE(x) ((x)*(x)) Используем шаблон: template<typename T> constexpr T square(T x) { return x * x; } 👉 Вместо #ifdef DEBUG ... #endif Используем: #ifdef DEBUG inline constexpr bool is_debug = true; #else inline constexpr bool is_debug = false; #endif А дальше просто: if constexpr (is_debug) { std::cout << "Debug mode\n"; } 💡 constexpr, inline, template и if constexpr — это ваш новый арсенал для выразительного и безопасного кода без макросов. ➡️ @cpp_geek
879
7
🧵 RAII — главный секрет устойчивого к утечкам C++ кода Привет! Сегодня хочу напомнить о технике, без которой невозможно писа
🧵 RAII — главный секрет устойчивого к утечкам C++ кода Привет! Сегодня хочу напомнить о технике, без которой невозможно писать безопасный и устойчивый C++ код — это RAII (Resource Acquisition Is Initialization). RAII — это идиома, в которой захват ресурса (файл, сокет, память, мьютекс) происходит в конструкторе объекта, а освобождение — в деструкторе. Благодаря этому ресурсы освобождаются автоматически, даже при исключениях. Пример: #include <fstream> void saveData(const std::string& filename) { std::ofstream file(filename); // открытие файла if (!file.is_open()) throw std::runtime_error("Cannot open file"); file << "some data"; // файл закроется автоматически } RAII делает твой код: ✅ Безопасным к утечкам ✅ Устойчивым к исключениям ✅ Лёгким для чтения и сопровождения 💡 Совет: всегда оборачивай "ручные" ресурсы в обёртки — std::unique_ptr, std::lock_guard, std::ofstream, std::thread и т.д. ➡️ @cpp_geek
760
8
Как отслужить срочку, работая с Геранями, и получить диплом по дуальной системе Алабуга Политех?
Как отслужить срочку, работая с Геранями, и получить диплом по дуальной системе Алабуга Политех?
685
9
Как упростить дебаг через std::format и std::source_location Когда вы отлаживаете сложный баг, бывает сложно быстро понять, г
Как упростить дебаг через std::format и std::source_location Когда вы отлаживаете сложный баг, бывает сложно быстро понять, где и почему произошла ошибка. С C++20 стало гораздо проще автоматизировать логирование и сделать его по-настоящему информативным. Вот пример: #include <iostream> #include <format> #include <source_location> void log(const std::string& message, const std::source_location location = std::source_location::current()) { std::cout << std::format("[{}:{} - {}] {}\n", location.file_name(), location.line(), location.function_name(), message); } int divide(int a, int b) { if (b == 0) { log("Попытка деления на ноль"); return 0; } return a / b; } 📌 Этот код выведет: [main.cpp:16 - divide] Попытка деления на ноль Вы больше не пишете руками __FILE__, __LINE__ и __func__. Всё это делает std::source_location. А с std::format — красиво и читаемо. ➡️ @cpp_geek
890
10
📌 Как эффективно работать с std::unordered_map? Всем привет! Сегодня расскажу о том, как правильно работать с std::unordered_map, чтобы избежать неожиданных проблем с производительностью. 🔥 Почему std::unordered_map? std::unordered_map — это хеш-таблица в C++, обеспечивающая быстрый доступ к данным (O(1) в среднем). В отличие от std::map, который построен на красно-черном дереве (O(log N) доступ), unordered_map работает быстрее при больших объемах данных. ⚠️ Подводные камни и советы по оптимизации 1️⃣ Выбор хорошей хеш-функции Стандартные хеш-функции (`std::hash`) работают хорошо для примитивных типов, но если вы работаете со сложными структурами (например, std::pair или std::string), лучше использовать специализированные хешеры. struct MyHash { std::size_t operator()(const std::pair<int, int>& p) const { return std::hash<int>()(p.first) ^ (std::hash<int>()(p.second) << 1); } }; Использование ^ (xor) и сдвигов помогает уменьшить коллизии. 2️⃣ Избегайте частых рехеширований При вставке элементов хеш-таблица может перераспределять память (rehash), что затратно. Лучше заранее задать нужный размер: std::unordered_map<int, std::string> myMap; myMap.reserve(10000); // Уменьшаем количество рехеширований Это особенно полезно, если вы примерно знаете, сколько элементов будет в контейнере. 3️⃣ Оптимизация использования памяти Если ваш unordered_map хранит тяжелые структуры, можно использовать std::reference_wrapper или хранить данные по shared_ptr: std::unordered_map<int, std::shared_ptr<MyStruct>> myMap; Так вы избежите лишнего копирования. 4️⃣ Правильное использование find Перед operator[] всегда проверяйте, есть ли элемент в контейнере. Так вы избежите ненужных вставок: if (myMap.find(key) != myMap.end()) { // Обрабатываем существующий ключ } Или используйте try_emplace, чтобы избежать двойного вычисления ключа: myMap.try_emplace(key, "значение по умолчанию"); 📌 Вывод: std::unordered_map — мощный инструмент, но при неправильном использовании может работать неэффективно. Выбирайте хорошие хеш-функции, контролируйте рехеширование и оптимизируйте память. ➡️ @cpp_geek
896
11
🚀 Подборка полезных IT каналов в Max Системное администрирование, DevOps 📌 https://max.ru/i_odmin Все для системного администратора https://max.ru/bash_srv Bash Советы https://max.ru/sysadminof Книги для админов, полезные материалы https://max.ru/i_odmin_book Библиотека Системного Администратора https://max.ru/i_devops DevOps: Пишем о Docker, Kubernetes и др. https://max.ru/tipsysdmin Типичный Сисадмин 1C разработка 📌 https://max.ru/odin1c_rus Cтатьи, курсы, советы, шаблоны кода 1С Программирование C++📌 https://max.ru/cpp_lib Библиотека C/C++ разработчика Программирование Go📌 https://max.ru/golang_lib Библиотека Go (Golang) разработчика Программирование React📌 https://max.ru/react_lib React Программирование Python 📌 https://max.ru/python_of Python академия. https://max.ru/BookPython Библиотека Python разработчика Java разработка 📌 https://max.ru/bookjava Библиотека Java разработчика GitHub Сообщество 📌 https://max.ru/githublib Интересное из GitHub Базы данных (Data Base) 📌 https://max.ru/database_info Все про базы данных Фронтенд разработка 📌 https://max.ru/frontend_1 Подборки для frontend разработчиков Библиотеки 📌 https://max.ru/programmist_of Книги по программированию https://max.ru/proglb Библиотека программиста https://max.ru/bfbook Книги для программистов Программирование 📌 https://max.ru/bookflow Лекции, видеоуроки, доклады с IT конференций https://max.ru/itmozg Программисты, дизайнеры, новости из мира IT https://max.ru/php_lib Библиотека PHP программиста 👨🏼‍💻👩‍💻 Шутки программистов 📌 https://max.ru/itumor Шутки программистов Защита, взлом, безопасность 📌 https://max.ru/thehaking Канал о кибербезопасности https://max.ru/xakkep_1 Хакер Free Книги, статьи для дизайнеров 📌 https://max.ru/odesigners Статьи, книги для дизайнеров Математика 📌 https://max.ru/Pomatematike Канал по математике https://max.ru/phismat_1 Обучающие видео, книги по Физике и Математике Вакансии 📌 https://max.ru/progjob Вакансии в IT Мир технологий 📌 https://max.ru/mir_teh Канал для любознательных Бонус 📌 https://max.ru/piterspb_78 Свежие новости Санкт-Петербурга https://max.ru/mockva_life Свежие новости Москвы
681
12
⚡ std::span — мощная альтернатива std::vector и std::array Сегодня поговорим о std::span — контейнере, который делает работу с массивами и векторами в C++ более удобной и эффективной. 🚀 ❌ Проблема: Лишние копии данных Представьте, что у нас есть функция, принимающая массив чисел: void processArray(const std::vector<int>& arr) { for (int num : arr) { std::cout << num << " "; } std::cout << std::endl; } С одной стороны, передача const std::vector<int>& предотвращает копирование, но что, если у нас массив std::array или сырой int[]? Придётся перегружать функцию или копировать данные в std::vector. ✅ Решение: Используем std::span std::span позволяет передавать любой диапазон (`std::vector`, std::array, сырые массивы) без копирования: #include <iostream> #include <span> #include <vector> #include <array> void processArray(std::span<int> arr) { for (int num : arr) { std::cout << num << " "; } std::cout << std::endl; } int main() { std::vector<int> vec = {1, 2, 3, 4, 5}; std::array<int, 5> arr = {6, 7, 8, 9, 10}; int rawArr[] = {11, 12, 13, 14, 15}; processArray(vec); // ✅ Работает processArray(arr); // ✅ Работает processArray(rawArr); // ✅ Работает } 🚀 Преимущества std::span ✅ Не копирует данные — передаётся как ссылка ✅ Работает с любыми последовательностями ✅ Гибкость — можно создавать срезы без копий Пример использования .subspan(), чтобы передавать часть массива: std::vector<int> vec = {1, 2, 3, 4, 5}; std::span<int> sp = vec; processArray(sp.subspan(2)); // Выведет: 3 4 5 ⚠️ Важно - std::span не владеет данными. Убедитесь, что исходные данные живут дольше span. - Не поддерживает автоматическое изменение размера, как std::vector. 📌 Итог Если ваша функция принимает std::vector<int>&, std::array<int, N>&, int[] или даже std::initializer_list<int>, замените их на std::span<int>! Это сделает код более гибким и эффективным. 🔥 ➡️ @cpp_geek
806
13
📌 Оптимизация работы со строками в C++: std::string_view vs std::string Привет, друзья! Сегодня хочу обсудить одну из самых частых проблем в C++ – работу со строками. А именно, почему std::string_view – это мощный инструмент, который может значительно ускорить ваш код. ❌ Проблема: Копирование строк Допустим, у вас есть функция, которая принимает строку: void process(std::string s) { // работа со строкой } Каждый раз, когда вызывается эта функция, создаётся новая копия строки. Если строка длинная, это дорого по времени и памяти. ✅ Решение: Используем std::string_view С std::string_view можно избежать лишнего копирования: void process(std::string_view s) { // работа со строкой без копирования } Теперь s – это просто представление строки, а не её копия. Вы можете передавать как std::string, так и char*, что делает API более гибким. 🚀 Преимущества std::string_view: ✔ Не создает копий – работает быстрее. ✔ Поддерживает стандартные операции (substr, find и т. д.). ✔ Работает с std::string, char*, массивами символов. ✔ Идеально подходит для парсинга и работы с текстом. 🔥 Важно помнить: - std::string_view не управляет памятью, так что будьте осторожны с временными строками. - Если строка-источник уничтожена, std::string_view станет невалидным. Пример неверного использования: std::string_view bad() { std::string s = "Hello"; return s; // ⚠ UB, строка уничтожена! } ➡️ @cpp_geek
818
14
🚀 Подборка полезных IT каналов в Max Системное администрирование, DevOps 📌 https://max.ru/i_odmin Все для системного администратора https://max.ru/bash_srv Bash Советы https://max.ru/sysadminof Книги для админов, полезные материалы https://max.ru/i_odmin_book Библиотека Системного Администратора https://max.ru/i_devops DevOps: Пишем о Docker, Kubernetes и др. https://max.ru/tipsysdmin Типичный Сисадмин 1C разработка 📌 https://max.ru/odin1c_rus Cтатьи, курсы, советы, шаблоны кода 1С Программирование C++📌 https://max.ru/cpp_lib Библиотека C/C++ разработчика Программирование Go📌 https://max.ru/golang_lib Библиотека Go (Golang) разработчика Программирование React📌 https://max.ru/react_lib React Программирование Python 📌 https://max.ru/python_of Python академия. https://max.ru/BookPython Библиотека Python разработчика Java разработка 📌 https://max.ru/bookjava Библиотека Java разработчика GitHub Сообщество 📌 https://max.ru/githublib Интересное из GitHub Базы данных (Data Base) 📌 https://max.ru/database_info Все про базы данных Фронтенд разработка 📌 https://max.ru/frontend_1 Подборки для frontend разработчиков Библиотеки 📌 https://max.ru/programmist_of Книги по программированию https://max.ru/proglb Библиотека программиста https://max.ru/bfbook Книги для программистов Программирование 📌 https://max.ru/bookflow Лекции, видеоуроки, доклады с IT конференций https://max.ru/itmozg Программисты, дизайнеры, новости из мира IT https://max.ru/php_lib Библиотека PHP программиста 👨🏼‍💻👩‍💻 Шутки программистов 📌 https://max.ru/itumor Шутки программистов Защита, взлом, безопасность 📌 https://max.ru/thehaking Канал о кибербезопасности https://max.ru/xakkep_1 Хакер Free Книги, статьи для дизайнеров 📌 https://max.ru/odesigners Статьи, книги для дизайнеров Математика 📌 https://max.ru/Pomatematike Канал по математике https://max.ru/phismat_1 Обучающие видео, книги по Физике и Математике Вакансии 📌 https://max.ru/progjob Вакансии в IT Мир технологий 📌 https://max.ru/mir_teh Канал для любознательных Бонус 📌 https://max.ru/piterspb_78 Свежие новости Санкт-Петербурга https://max.ru/mockva_life Свежие новости Москвы
696
15
🚀 Оптимизация циклов в C++: маленькие хитрости для больших скоростей Сегодня поговорим об оптимизации циклов в C++. Даже если ваш код работает, это не значит, что он работает быстро. Давайте разберём несколько трюков, которые помогут выжать максимум из циклов. 🔥 1. Избегайте ненужных вычислений внутри цикла ❌ Плохо: for (int i = 0; i < vec.size(); i++) { process(vec[i]); } ✅ Хорошо: size_t size = vec.size(); for (size_t i = 0; i < size; i++) { process(vec[i]); } Почему? vec.size() может вызываться при каждой итерации, что может замедлить выполнение, особенно если это не std::vector, а другой контейнер. ⚡ 2. Используйте reserve() для вектора Если вы заранее знаете, сколько элементов добавите в std::vector, вызовите reserve(). Это сократит количество реаллокаций памяти. std::vector<int> vec; vec.reserve(1000); // резервируем место для 1000 элементов for (int i = 0; i < 1000; i++) { vec.push_back(i); } 🏎️ 3. Предпочитайте range-based for Классический цикл for: for (size_t i = 0; i < vec.size(); i++) { process(vec[i]); } Современный range-based for: for (const auto& elem : vec) { process(elem); } Плюсы: ✅ Улучшает читаемость ✅ Избегает ненужных индексаций ✅ Позволяет компилятору оптимизировать код 🔄 4. std::transform вместо for Если вы преобразуете данные из одного контейнера в другой, используйте std::transform: std::vector<int> src = {1, 2, 3, 4, 5}; std::vector<int> dst(src.size()); std::transform(src.begin(), src.end(), dst.begin(), [](int x) { return x * 2; }); Зачем? ✔️ Работает быстрее за счёт оптимизаций ✔️ Код становится короче и читабельнее 🎯 Вывод Оптимизация циклов — это не магия, а грамотное использование возможностей C++. Убирайте лишние вычисления, используйте reserve(), применяйте range-based for и std::transform, и ваш код станет быстрее и элегантнее. Используете ли вы std::transform в своём коде? Делитесь в комментариях! 👇 ➡️ @cpp_geek
794
16
Какие есть особенности статических полей класса в языке С++? Статические поля класса в C++ имеют несколько особенностей: 1. Общий доступ: статические поля являются общими для всех объектов этого класса. Это означает, что изменение значения статического поля в одном объекте, изменяет его для всех объектов этого класса. 2. Инициализация: статические поля инициализируются только один раз, когда программа запускается. Значения статических полей сохраняются на протяжении всего времени работы программы. 3. Доступ: доступ к статическим полям класса возможен без создания объекта этого класса, например, используя имя класса и оператор :: . 4. Память: статические поля класса хранятся не в куче или стеке, а в статической области памяти, что позволяет им занимать память только один раз, независимо от количества созданных объектов класса. ➡️ @cpp_geek
703
17
🚀 Подборка полезных IT каналов в Max Системное администрирование, DevOps 📌 https://max.ru/i_odmin Все для системного администратора https://max.ru/bash_srv Bash Советы https://max.ru/sysadminof Книги для админов, полезные материалы https://max.ru/i_odmin_book Библиотека Системного Администратора https://max.ru/i_devops DevOps: Пишем о Docker, Kubernetes и др. https://max.ru/tipsysdmin Типичный Сисадмин 1C разработка 📌 https://max.ru/odin1c_rus Cтатьи, курсы, советы, шаблоны кода 1С Программирование C++📌 https://max.ru/cpp_lib Библиотека C/C++ разработчика Программирование Go📌 https://max.ru/golang_lib Библиотека Go (Golang) разработчика Программирование React📌 https://max.ru/react_lib React Программирование Python 📌 https://max.ru/python_of Python академия. https://max.ru/BookPython Библиотека Python разработчика Java разработка 📌 https://max.ru/bookjava Библиотека Java разработчика GitHub Сообщество 📌 https://max.ru/githublib Интересное из GitHub Базы данных (Data Base) 📌 https://max.ru/database_info Все про базы данных Фронтенд разработка 📌 https://max.ru/frontend_1 Подборки для frontend разработчиков Библиотеки 📌 https://max.ru/programmist_of Книги по программированию https://max.ru/proglb Библиотека программиста https://max.ru/bfbook Книги для программистов Программирование 📌 https://max.ru/bookflow Лекции, видеоуроки, доклады с IT конференций https://max.ru/itmozg Программисты, дизайнеры, новости из мира IT https://max.ru/php_lib Библиотека PHP программиста 👨🏼‍💻👩‍💻 Шутки программистов 📌 https://max.ru/itumor Шутки программистов Защита, взлом, безопасность 📌 https://max.ru/thehaking Канал о кибербезопасности https://max.ru/xakkep_1 Хакер Free Книги, статьи для дизайнеров 📌 https://max.ru/odesigners Статьи, книги для дизайнеров Математика 📌 https://max.ru/Pomatematike Канал по математике https://max.ru/phismat_1 Обучающие видео, книги по Физике и Математике Вакансии 📌 https://max.ru/progjob Вакансии в IT Мир технологий 📌 https://max.ru/mir_teh Канал для любознательных Бонус 📌 https://max.ru/piterspb_78 Свежие новости Санкт-Петербурга https://max.ru/mockva_life Свежие новости Москвы
714
18
📌 Оптимизация кода с std::optional в C++ Привет, друзья! Сегодня поговорим про std::optional — мощный инструмент, который делает код чище и безопаснее. 💡 Зачем нужен std::optional? Обычно, если функция не может вернуть корректное значение, приходится использовать: ✔ Возвращаемое значение с ошибочным кодом (неудобно, особенно если 0 или -1 могут быть валидными). ✔ Выброс исключения (дорого по ресурсам). ✔ Указатели (nullptr, но требует дополнительных проверок). 🔥 Альтернатива? Используем std::optional! #include <iostream> #include <optional> #include <string> std::optional<std::string> findUser(int id) { if (id == 42) return "John Doe"; return std::nullopt; } int main() { auto user = findUser(42); if (user) { std::cout << "User found: " << *user << std::endl; } else { std::cout << "User not found!" << std::endl; } } ✅ Код стал чище: нет лишних проверок nullptr, исключений или специальных значений. 🎯 Когда использовать? 🔹 Когда функция может вернуть "ничего", но исключения и специальные значения не подходят. 🔹 Для более понятного API (например, парсинг строки в число). 🔹 Когда важно избежать неопределенного состояния (например, с переменной внутри класса). А ты уже используешь std::optional в своем коде? Делись опытом в комментариях! ⬇🔍 ➡️ @cpp_geek
921
19
Бинарный поиск Чаще всего бинарный поиск (бинпоиск) используют, чтобы найти элемент в отсортированном массиве. Мы начинаем ис
Бинарный поиск Чаще всего бинарный поиск (бинпоиск) используют, чтобы найти элемент в отсортированном массиве. Мы начинаем искать с середины массива. Если находим то, что нужно, или если больше нечего рассматривать, мы останавливаемся. В противном случае мы решаем, в каком направлении — вправо или влево от середины — мы должны продолжить поиск. Так как пространство поиска после каждой проверки делится на два, то время выполнения алгоритма — O(log n). Код выводит следующее: бинарный поиск: нашли по индексу 4 Если искомый элемент не найден, но мы хотим найти ближайший элемент меньше или больше запроса, то можно использовать функции STL lower_bound() и upper_bound(). ➡️ @cpp_geek
772
20
Напишите базовую реализацию std::shared_ptr std::shared_ptr — умный указатель, который позволяет разделять владение объектом
Напишите базовую реализацию std::shared_ptr std::shared_ptr — умный указатель, который позволяет разделять владение объектом между несколькими shared_ptr. Когда последний shared_ptr уничтожается, он автоматически удаляет объект. ➡️ @cpp_geek
870