2026-01-04 20:40:07 +01:00
2026-01-04 20:40:07 +01:00
2026-01-04 20:40:07 +01:00
2026-01-04 20:40:07 +01:00
2026-01-04 20:40:07 +01:00
2026-01-04 20:40:07 +01:00
2026-01-04 20:40:07 +01:00
2026-01-04 20:40:07 +01:00
2026-01-04 20:40:07 +01:00
2026-01-04 20:40:07 +01:00
2026-01-04 20:40:07 +01:00
2026-01-04 20:40:07 +01:00
2026-01-04 20:40:07 +01:00
2026-01-04 20:40:07 +01:00
2026-01-04 20:40:07 +01:00
2026-01-04 20:40:07 +01:00
2026-01-04 20:40:07 +01:00
2026-01-04 20:40:07 +01:00
2026-01-04 20:40:07 +01:00

🥋 Go Katas 🥋

"I fear not the man who has practiced 10,000 kicks once, but I fear the man who has practiced one kick 10,000 times." (Bruce Lee)

What should it be?

  • Go is simple to learn, but nuanced to master. The difference between "working code" and "idiomatic code" often lies in details such as safety, memory efficiency, and concurrency control.

  • This repository is a collection of Daily Katas: small, standalone coding challenges designed to drill specific Go patterns into your muscle memory.

What should it NOT be?

  • This is not intended to teach coding, having Go as the programming mean. Not even intended to teach you Go in general
  • The focus should be as much as possible challenging oneself to solve common software engineering problems the Go way.
  • Several seasoned developers spent years learning and applying best-practices at prod-grade context. Once they decide to switch to go, they would face two challanges:
    • Is there a window of knowledge transform here, so that I don't have to through years of my career from the window at start from zero?
    • If yes, the which parts should I focus on to recognize the mismatches and use them the expected way in the Go land?

How to Use This Repo

  1. Pick a Kata: Navigate to any XX-kata-yy folder.
  2. Read the Challenge: Open the README.md inside that folder. It defines the Goal, the Constraints, and the "Idiomatic Patterns" you must use.
  3. Solve It: Initialize a module inside the folder and write your solution.
  4. Reflect: Compare your solution with the provided "Reference Implementation" (if available) or the core patterns listed.

Contribution Guidelines

Have a favorite Go pattern?

  1. Create a new folder XX-your-topic. (XX is an ordinal number)
  2. Copy the README_TEMPLATE.md to the new folder as README.md
  3. Define the challenge: focus on real-world scenarios (e.g., handling timeouts, zero-allocation sets), and idiomatic Go, not just algorithmic puzzles.
  4. Optionally, create a main.go or any other relevant files under the project containing blueprint of the implementation, as long as you think it reduces confusion and keeps the implementation focused
  5. Submit a PR.

Using the script

You can use the shorthand script to add a new challenge, it will create a new folder and a new README.md file under it:

./add.sh my-very-creative-challange

This will create a new folder 21-my-very-creative-challange (in case the latest challange was under the folder name 20-latest-name-here) and add a README.md under it

medunes@medunes:~/projects/go-kata$  ls 21-my-very-creative-challange/
README.md
Description
No description provided
Readme MIT 84 KiB
Languages
Go 96.1%
Makefile 3.9%