В этом декабре 2025 рабочая неделя сжалась до минимума. Только понедельник и вторник в деле, а дальше праздники до 12 января.
Для разработчиков такие дни часто превращаются в формальность. Кто-то доделывает мелкие таски, чтобы Jira не напоминала в отпуске.
Другие чистят код от предупреждений линтера или пишут тесты, которые откладывали месяцами. Есть и те, кто просто мониторит продакшн, попивая кофе у монитора.
📍 Навигация: Вакансии • Задачи • Собесы
#GoTalk
Please open Telegram to view this post
VIEW IN TELEGRAM
❤5👾1
В Go важно понимать что произошло при чтении данных. Значение реально есть или это просто нулевое значение. Для этого в языке есть привычная конструкция value, ok.
Самый частый кейс это map. Если обратиться к мапе по ключу и ключа нет, Go вернет нулевое значение типа. Проблема в том, что нулевое значение может быть и настоящим значением.
Пример:
users := map[int]string{
1: "Alice",
2: "",
}
name := users[2] // вернет пустую строку и непонятно почему
missing := users[99] // тоже пустая строка и опять непонятно почему
name2, ok2 := users[2] // ok2 true
missing2, ok3 := users[99] // ok3 false
_ = name
_ = missing
_ = name2
_ = missing2Если нужно только проверить наличие ключа, значение можно игнорировать через
_:if _, ok := users[42]; !ok {
// ключа нет
}Второй важный кейс это type assertion. Когда есть
interface{} и нужно безопасно проверить что внутри лежит конкретный тип, запись s, ok := v.(string) не падает с panic и позволяет обработать ситуацию нормально.Пример:
var v any = "hello"
s, ok := v.(string)
if ok {
_ = s
} else {
// внутри не string
}
Это базовая защита от двусмысленности. В мапах она отличает отсутствующий ключ от нулевого значения, в интерфейсах помогает проверять тип без panic.
📍 Навигация: Вакансии • Задачи • Собесы
#GoToProduction
Please open Telegram to view this post
VIEW IN TELEGRAM
👍16❤2
time.Sleep выглядит просто для пауз в коде, но игнорирует контекст. При shutdown функция досидит задержку и только потом проверит ctx.Done().В цикле типа
for { work(); time.Sleep(5*time.Second) } сигнал отмены не прервёт сон. Функция проснётся, выполнит код и упадёт с ошибкой. В проде это растягивает graceful shutdown.Лучше
select { case <-ctx.Done(): return; default: time.Sleep(d) }. Но sleep всё равно ждёт полного времени — до 5 секунд задержки. Ещё хуже:
time.After(d) создаёт таймер каждый раз, аллоцирует память и утечь.Оптимально — один таймер:
t := time.NewTimer(d)
for {
select {
case <-ctx.Done():
if !t.Stop() { <-t.C }
return
case <-t.C:
t.Reset(d)
}
work()
}
Таймер переиспользуется, останавливается чисто.
Ticker не подходит: тикает независимо от длительности work(), может запускать задачи внахлёст.📍 Навигация: Вакансии • Задачи • Собесы
#GoDeep
Please open Telegram to view this post
VIEW IN TELEGRAM
👏15👍4❤1👾1
🤔 Не знаете, в чём встречать Новый год? Не беда!
Tproger как раз собрал стек новогодних нарядов, чтобы вы сияли ярче, чем любая гирлянда. Скорее заходите в виртуальную примерочную и выбирайте скин! 💃
Реклама. ИП Михайлишина Гузель Фаниловна.
ИНН 165042823905. Erid 2VtzqukJLdp
Tproger как раз собрал стек новогодних нарядов, чтобы вы сияли ярче, чем любая гирлянда. Скорее заходите в виртуальную примерочную и выбирайте скин! 💃
Реклама. ИП Михайлишина Гузель Фаниловна.
ИНН 165042823905. Erid 2VtzqukJLdp
😁9❤1👍1
Свежее сравнение трёх SQLite драйверов в Go 1.25.2: mattn/go-sqlite3, modernc/sqlite, ncruces/go-sqlite3. Тесты на 15 платформах от M1 до RISC-V.
Modernc выиграл общий зачёт. Лучше читает данные и работает с нагрузкой. Mattn хорош только на вставку. Ncruces просто третий.
📍 Навигация: Вакансии • Задачи • Собесы
#GoLive
Please open Telegram to view this post
VIEW IN TELEGRAM
👍9🤔5❤1
💻 Переменные прямо в if
В Go можно объявлять переменные прямо в условии if. Это помогает не разносить временные переменные по всей функции и не держать их живыми дольше чем нужно.
Синтаксис выглядит так
Init statement выполняется перед проверкой условия, а переменные из него доступны в
Самый популярный кейс это обработка ошибок рядом с вызовом функции:
Плюс подхода в том, что
📍 Навигация: Вакансии • Задачи • Собесы
🐸 Библиотека Go-разработчика
#GoToProduction
В Go можно объявлять переменные прямо в условии if. Это помогает не разносить временные переменные по всей функции и не держать их живыми дольше чем нужно.
Синтаксис выглядит так
if init statement; condition { ... } else { ... }Init statement выполняется перед проверкой условия, а переменные из него доступны в
condition и в ветках if и else, но не доступны после if.Самый популярный кейс это обработка ошибок рядом с вызовом функции:
if f, err := os.Open("config.json"); err != nil {
// ошибка открытия
} else {
defer f.Close()
// работа с f
}Плюс подхода в том, что
f и err не остаются в области видимости функции. Это снижает риск случайно использовать не тот err ниже по коду или затереть переменную новым значением.📍 Навигация: Вакансии • Задачи • Собесы
#GoToProduction
Please open Telegram to view this post
VIEW IN TELEGRAM
❤9👍7🥱3
Пока вы думаете, что «не хватает времени» или «сложные обстоятельства» — Стас перенёс две нейрохирургические операции, собирает себя по кусочкам, при этом проходит курс по C++, пилит проекты для портфолио и откликается на вакансии.
📍 Навигация: Вакансии • Задачи • Собесы
Please open Telegram to view this post
VIEW IN TELEGRAM
🙏10
AI-запросы к моделям типа GPT или Llama непредсказуемы по времени. Сервис может зависнуть на час, если провайдер тормозит.
Оборачивайте каждый вызов в контекст:
ctx, cancel := context.WithTimeout(parentCtx, 30*time.Second)
defer cancel()
response, err := client.Generate(ctx, prompt)
Таймаут рубит запрос, освобождает горутину и соединение. Без него один медленный запрос забьёт пул, вызовет каскад отказов.
Middleware паттерн:
func AIHandler(next http.Handler) http.Handler {
return http.HandlerFunc(func(w, r) {
ctx, cancel := context.WithTimeout(r.Context(), 60*time.Second)
defer cancel()
next.ServeHTTP(w, r.WithContext(ctx))
})
}📍 Навигация: Вакансии • Задачи • Собесы
#GoDeep
Please open Telegram to view this post
VIEW IN TELEGRAM
❤7🌚4👍3
🆚 Два способа создать пустой байтовый слайс
Разница:
Семантика:
Правило:
📍 Навигация: Вакансии • Задачи • Собесы
🐸 Библиотека Go-разработчика
#GoDeep
[]byte{} не равно []byte(nil). Оба пустые, но []byte{} == nil == false []byte(nil) == nil == true.Разница:
// json.Unmarshal сломается на nil
err := json.Unmarshal(data, &result) // ошибка на []byte(nil)
// append ведёт себя по-разному
append([]byte{}, 1) // новый слайс [1]
append([]byte(nil), 1) // новый слайс [1] (Go фиксит)
Семантика:
[]byte{} — "пустой буфер, готов к работе"
[]byte(nil) — "данных нет вообще"Правило:
[]byte{} в 99% случаев. nil только для явного отсутствия.📍 Навигация: Вакансии • Задачи • Собесы
#GoDeep
Please open Telegram to view this post
VIEW IN TELEGRAM
👍9❤2🤔1
time.Sleep(10 * 24 * time.Hour) // заслуженный отдых
fmt.Println("🎉 С Новым годом!")
Желаем быстрых билдов, понятных ошибок и
defer только для закрытия ресурсов, а не дедлайнов.Please open Telegram to view this post
VIEW IN TELEGRAM
1❤45🎉15👍4
Новый год пришёл, но контент не останавливается. Все праздники публикуем топ посты прошлого года — те самые, что сохраняли в закладки.
📍 Навигация: Вакансии • Задачи • Собесы
Please open Telegram to view this post
VIEW IN TELEGRAM
👍2
Весной мы рассказывали о Swiss Table — новом алгоритме хеш-таблиц в Go 1.24. Тогда прошлись по верхам, теперь копнём глубже: как именно устроена map под капотом.
Раньше мапа хранила данные в бакетах со связными списками при переполнении. Теперь — массив групп, каждая содержит 8 слотов для пар ключ-значение и 64-битное контрольное слово.
Каждый байт контрольного слова хранит статус слота: пусто / занято / удалено и 7 бит от хеша ключа.
Как работает поиск
Хеш ключа разбивается на две части:
• h1 (старшие 57 бит) — определяет группу
• h2 (младшие 7 бит) — «отпечаток» для быстрого сравнения
Вместо последовательного сравнения 8 ключей Go сравнивает h2 сразу со всеми 8 байтами контрольного слова за одну SIMD-операцию. Не совпало — слот пропускается. Совпало — проверяется полный ключ.
Инкрементальный рост
Abseil (C++) перестраивает всю таблицу разом. Go так не может — это убьёт latency. Поэтому мапа разбита на независимые таблицы по 1024 записи максимум. При переполнении растёт только одна таблица, остальные не трогаются.
Итог:
Память: −15–25% за счёт компактного хранения
Скорость: до +60% на микробенчмарках
Load factor выше — меньше перестроений
📍 Навигация: Вакансии • Задачи • Собесы
#лучшее_из_библиотеки_2025
Please open Telegram to view this post
VIEW IN TELEGRAM
👍17❤4🤔2
В середине года мы спрашивали у вас про вашу любимую IDE. Повторим опрос? Тогда лагеря разделились почти поровну между VS Code и GoLand.
Поставьте эмоцию соответствующую вашей IDE:
👍 — VS Code
🤩 — GoLand
👾 — Другие IDE
📍 Навигация: Вакансии • Задачи • Собесы
#лучшее_из_библиотеки_2025
Please open Telegram to view this post
VIEW IN TELEGRAM
🤩155👍144👾57🥱2
2025-й стал годом «скучной стабильности» в айти. Компании не росли — выживали: резали бюджеты, оптимизировали команды, затягивали найм.
2383 отклика на 1 вакансию.
−20% позиций за год.
30-50% сокращений в e-commerce.
📍 Навигация: Вакансии • Задачи • Собесы
Please open Telegram to view this post
VIEW IN TELEGRAM
😢13😁2👾2
Когда проект на Go становится больше пары пакетов, держать в голове связи между функциями — задача неблагодарная.
go-callvis решает эту проблему: он строит интерактивную диаграмму вызовов прямо из кода.
Как установить:
go install github.com/ofabry/go-callvis@latest
Главная команда:
go-callvis ./...
Это запустит HTTP-сервер по адресу https://localhost:7878/, где можно интерактивно просматривать граф вызовов.
📍 Навигация: Вакансии • Задачи • Собесы
#лучшее_из_библиотеки_2025
Please open Telegram to view this post
VIEW IN TELEGRAM
👍19❤🔥3👏2
Весной мы рассказывали про Watermill, фреймворк для Go, который упрощает обработку сообщений. Поддерживает Kafka, RabbitMQ, NATS и другие брокеры.
Фреймворк дает маршрутизацию по темам, гибкую настройку под микросервисы. Встроены метрики и логи, чтобы следить за потоком. От простых очередей до распределенных систем работает стабильно.
Код простой: роутер подключаете, хендлер с subscriber и publisher. Сообщение приходит, обрабатываете, дальше шлёте. Идеально для заказов в e-commerce или аналитики.
Пример:
r := router.NewRouter(router.Config{}, logger)
r.AddHandler(
"order_handler",
"orders",
kafkaSubscriber,
"processed_orders",
rabbitPublisher,
func(msg *message.Message) ([]*message.Message, error) {
// Логика обработки сообщения
return []*message.Message{msg}, nil
},
)
r.Run()📍 Навигация: Вакансии • Задачи • Собесы
#лучшее_из_библиотеки_2025
Please open Telegram to view this post
VIEW IN TELEGRAM
🤔4❤2
Высокопроизводительные AI-агенты: пора строить экосистемы
Go идеально подходит для инфраструктуры ИИ, но чтобы управлять логикой моделей, нужны паттерны автономности. В 2026-м недостаточно уметь дёргать
На курсе «Разработка AI-агентов» мы учим строить автономные системы:
— использование паттерна
— оркестрация в
— внедрение протокола
— создание быстрых
Дипломный проект — автономная группа агентов, решающая задачи анализа рынка или автоматизации саппорта.
❄️ До 12 января действует акция «3 в 1»: забирай курс по ИИ-агентам и 2 дополнительных курса в подарок.
Ворваться в AI-разработку
Go идеально подходит для инфраструктуры ИИ, но чтобы управлять логикой моделей, нужны паттерны автономности. В 2026-м недостаточно уметь дёргать
OpenAI API.На курсе «Разработка AI-агентов» мы учим строить автономные системы:
— использование паттерна
ReAct для принятия решений агентом;— оркестрация в
n8n для управления сложными флоу;— внедрение протокола
MCP для обмена данными;— создание быстрых
RAG-систем для работы с контекстом.Дипломный проект — автономная группа агентов, решающая задачи анализа рынка или автоматизации саппорта.
❄️ До 12 января действует акция «3 в 1»: забирай курс по ИИ-агентам и 2 дополнительных курса в подарок.
Ворваться в AI-разработку
😁1
🧱 7 архитектурных паттернов, которые должен знать каждый программист
Архитектурные паттерны — это фундаментальные подходы, помогающие создавать масштабируемые, устойчивые и поддерживаемые решения.
В статье собрали и разобрали 7 архитектурных паттернов, которые сегодня стоит знать каждому разработчику.
📍 Навигация: Вакансии • Задачи • Собесы
🐸 Библиотека Go-разработчика
#лучшее_из_библиотеки_2025
Архитектурные паттерны — это фундаментальные подходы, помогающие создавать масштабируемые, устойчивые и поддерживаемые решения.
В статье собрали и разобрали 7 архитектурных паттернов, которые сегодня стоит знать каждому разработчику.
📍 Навигация: Вакансии • Задачи • Собесы
#лучшее_из_библиотеки_2025
Please open Telegram to view this post
VIEW IN TELEGRAM
🥱4👏1
📍 Навигация: Вакансии • Задачи • Собесы
#лучшее_из_библиотеки_2025
Please open Telegram to view this post
VIEW IN TELEGRAM
😁33❤4💯2
Одной командой и парой строк кода делаем кэш для вашего приложения.
Установка
go get github.com/patrickmn/go-cache
Быстрый пример
c := cache.New(5*time.Minute, 10*time.Minute)
c.Set("foo", "bar", cache.DefaultExpiration)
val, found := c.Get("foo")
if found {
fmt.Println("Found:", val)
}
• 5m — TTL по умолчанию для всех ключей
• 10m — интервал очистки просроченных ключей
• можно указать cache.NoExpiration — чтобы хранить вечно
Полезные методы
// Установить с TTL
c.Set("key", "value", time.Minute)
// Получить значение
c.Get("key")
// Удалить ключ
c.Delete("key")
// Очистить всё
c.Flush()
📍 Навигация: Вакансии • Задачи • Собесы
#лучшее_из_библиотеки_2025
Please open Telegram to view this post
VIEW IN TELEGRAM
❤10🌚7👍5
Zog – это библиотека, вдохновлённая Zod. Она позволяет гибко и декларативно проверять входные данные, минимизируя ручную обработку ошибок.
Где пригодится
• Валидация JSON-запросов в API
• Проверка параметров HTTP-запросов
• Чтение и проверка переменных окружения
• Минимизация кода валидации и ошибок
Пример использования:
var UserSchema = zog.Object(map[string]zog.Schema{
"username": zog.String().Min(3).Max(20),
"email": zog.String().Email(),
"age": zog.Number().Min(18),
})
func main() {
data := map[string]interface{}{
"username": "go_dev",
"email": "[email protected]",
"age": 25,
}
parsed, err := UserSchema.Parse(data)
if err != nil {
fmt.Println("Ошибка валидации:", err)
return
}
fmt.Println("Успешно:", parsed)
}Создаём схему UserSchema, где username должен быть строкой длиной от 3 до 20 символов, email – валидным email-адресом, а age – числом не меньше 18. Передаём тестовый JSON и проверяем его с помощью UserSchema.Parse().
🖇 Официальный репозиторий проекта
📍 Навигация: Вакансии • Задачи • Собесы
#лучшее_из_библиотеки_2025
Please open Telegram to view this post
VIEW IN TELEGRAM
❤12🔥4