Иногда функция ничего не находит, но вынуждена возвращать ноль или пустую строку; удобно дать этому состоянию отдельное, явно оформленное место.
В этом гайде:
• Как аккуратно выражать отсутствие результата в коде;
• Простой способ избежать магических значений ошибок;
• Научимся читать вызовы функций, не догадываясь по комментариям
Честно обозначенное «нет значения» делает интерфейсы проще, а ошибки поиска заметнее и предсказуемее.
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥14❤10🤝5👍4
Как перестать писать громоздкие циклы с индексами?
Классический вариант в C++ всё ещё часто выглядит так:
Здесь куча лишнего шума: тип индекса,
Легко ошибиться с границами (
С
Перебираем сразу элементы, а не индексы.
Тот же приём работает для
🔥 Используйте
📣 C++ Ready | #совет
Классический вариант в C++ всё ещё часто выглядит так:
for (std::size_t i = 0; i < names.size(); ++i) {
std::cout << names[i] << '\n';
}Здесь куча лишнего шума: тип индекса,
i < names.size(), доступ по names[i].Легко ошибиться с границами (
<= вместо <) или забыть обновить цикл, если контейнер поменялся.С
range-based for всё короче и безопаснее:for (const auto& name : names) {
std::cout << name << '\n';
}Перебираем сразу элементы, а не индексы.
Тот же приём работает для
std::vector, std::array, std::list, std::map и собственных контейнеров с begin()/end().range-based for по умолчанию, а циклы с индексом оставляйте только там, где действительно нужен номер элемента.Please open Telegram to view this post
VIEW IN TELEGRAM
🤝13❤7🔥5👍2
Разбираем небольшой планировщик дел, где каждая новая задача укладывается по важности так, что программа без сомнений знает, за что взяться первой.
В этом разборе:
• Посмотрим, как упорядочить дела так, чтобы важные всплывали первыми;
• Почувствуем, как код берёт на себя рутину выбора;
• Увидим, как из простых шагов собирается удобный маленький помощник.
После такого подхода список задач перестаёт пугать, а начать становится проще прямо сейчас для тебя.
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥16👍8❤5🤝4
Типобезопасные перечисления — enum class вместо старого enum!
Обычный
Сначала посмотрим на «старый»
Теперь перепишем на
🔥 Переход на
📣 C++ Ready | #практика
Обычный
enum неявно приводится к int и даёт сравнивать разные перечисления друг с другом — легко наделать странных багов.Сначала посмотрим на «старый»
enum и его проблемы:enum Color { Red, Green, Blue };
enum Status { Ok, Error };
int main() {
Color c = Red;
if (c == Ok) { } // компилируется, хотя Color и Status — разные enum'ы
}Теперь перепишем на
enum class, чтобы каждое перечисление стало отдельным типом с собственной областью имён:enum class Color { Red, Green, Blue };
enum class Status { Ok, Error };
int main() {
Color c = Color::Red;
Status s = Status::Ok;
// if (c == s) { } // ошибка компиляции: разные типы
}enum class не приводится к int по умолчанию, не пересекается по именам и сразу показывает, к какому именно набору значений относится переменная.enum class — простой шаг к более безопасному и читаемому коду с перечислениями.Please open Telegram to view this post
VIEW IN TELEGRAM
👍12❤9🔥4😁1
❤12👍6🔥5
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥24👍7❤5🤝1
Как запретить опасное копирование ещё на этапе компиляции?
Класс часто владеет ресурсом: файл, сокет, мьютекс.
Если такой объект случайно скопировать, ресурс могут закрыть дважды или использовать после освобождения — ловим странные баги.
В современном C++ не нужно придумывать трюки с приватными конструкторами.
Достаточно явно запретить операции через
Теперь любой код, который останавливается ещё на стадии сборки, например:
Тем же приёмом можно отключать нежелательные перегрузки функций:
🔥 Итог:
«эту операцию делать нельзя», и превратить потенциальный рантайм-баг в понятную ошибку компиляции.
📣 C++ Ready | #совет
Класс часто владеет ресурсом: файл, сокет, мьютекс.
Если такой объект случайно скопировать, ресурс могут закрыть дважды или использовать после освобождения — ловим странные баги.
В современном C++ не нужно придумывать трюки с приватными конструкторами.
Достаточно явно запретить операции через
= delete:struct File {
File(const std::string& path);
File(const File&) = delete;
File& operator=(const File&) = delete;
};Теперь любой код, который останавливается ещё на стадии сборки, например:
File a{"data.txt"};
File b = a; // ❌ не скомпилируетсяТем же приёмом можно отключать нежелательные перегрузки функций:
void print(double);
void print(int) = delete; // запретить неявное приведение int → double
= delete — простой способ сказать компилятору«эту операцию делать нельзя», и превратить потенциальный рантайм-баг в понятную ошибку компиляции.
Please open Telegram to view this post
VIEW IN TELEGRAM
❤16🔥8🤝6👍1
Программисты, это вам 👇
Держите 5 каналов, которые реально помогают изучать программирование и IT с полного нуля:
🖥 Easy Coder — все направления IT.
👩💻 Easy Python — всё о Python.
🌐 Easy WebDev — Frontend, Backend.
🔠 Easy InfoSec — ИБ, Хакинг.
🐱 Easy GitHub — лучшее с GitHub.
Тонны полезной инфы для любого уровня подготовки✔️
Держите 5 каналов, которые реально помогают изучать программирование и IT с полного нуля:
🌐 Easy WebDev — Frontend, Backend.
Тонны полезной инфы для любого уровня подготовки
Please open Telegram to view this post
VIEW IN TELEGRAM
❤3👍1🔥1