新手学Go应优先实践四个项目:①带错误处理的命令行计算器,练基础语法与errors;②用net/http写极简REST API,理解路由与JSON序列化;③用Redis实现分布式锁,掌握并发安全与Lua原子操作;④用Gin+GORM+JWT搭用户认证API,覆盖工程化核心链路。

直接上手写能跑通、有输入输出、带点真实感的小项目,比死磕语法更有效。下面这四个方向,按难度和收获比排序,新手照着做一周就能建立信心。
写一个带错误处理的命令行计算器
这是最不绕弯的起点:不用配环境、不碰数据库、不搞网络,专注 Go 基础语法 + 错误处理 + 包组织。很多人卡在 errors.New 和多返回值怎么接,这个项目刚好练透。
- 把加减乘除拆成独立函数,每个都返回
(int, error),比如Div(a, b int) (int, error) -
main.go里用flag包接收参数,例如go run main.go -op add -a 5 -b 3 - 务必测试除零、非法操作符等边界,观察 panic 和 error 的区别
- 别急着加浮点或表达式解析——先让整数四则运算稳稳跑通
用 net/http 写个极简 REST API(不用框架)
Go 的标准库 net/http 足够写出可用的 API,强行上 Gin 反而掩盖了路由分发、请求解析、JSON 序列化这些底层逻辑。新手常以为“没框架就不会写 Web”,其实恰恰相反。
- 只用
http.HandleFunc注册两个路由:/users(返回 JSON 列表)和/users/1(返回单个用户) - 用户数据硬编码在内存切片里,避免一上来就被数据库绊住
- 手动调
json.NewEncoder(w).Encode(),而不是依赖框架自动序列化 - 重点体会:为什么必须设
w.Header().Set("Content-Type", "application/json")?漏了会怎样?
实现一个 Redis 分布式锁(用 redis-tools 或 lua 脚本)
一旦你写过几个小工具,就会遇到“并发安全”问题。这时引入 Redis 锁,既能接触真实中间件,又不需要理解整个分布式系统。很多新手抄代码却不知道 EVAL 脚本里那句 if redis.call("get", KEYS[1]) == ARGV[1] 在防什么。
立即学习“go语言免费学习笔记(深入)”;
- 用
github.com/go-redis/redis/v9连 Redis,不要用老版本 - 锁的 value 必须是唯一随机字符串(比如
uuid.NewString()),不能写死 - 解锁必须用 Lua 脚本原子执行,否则出现“A 加锁 → B 超时释放 → A 解锁”这种经典误释放
- 先不考虑自动续期(renew),先把加锁、判断、解锁三步串起来跑通
用 Gin + GORM 搭一个用户注册登录 API
这是迈向工程化的临门一脚。Gin 负责 HTTP 层,GORM 负责数据层,JWT 负责鉴权——三个组件组合起来,已经覆盖大多数业务后端的核心链路。新手最容易在这里栽在配置顺序和中间件嵌套上。
- 数据库用 SQLite 就够,别一上来就折腾 MySQL 权限和连接池
- 密码必须用
golang.org/x/crypto/bcrypt加密,bcrypt.GenerateFromPassword的 cost 设为 12 - JWT 签发后,把 token 放在响应体里(不是 Header),前端好取;验证中间件里用
c.Get("user_id")传上下文,别全局变量 - 别急着加邮箱验证、短信登录——先确保 POST /register → POST /login → GET /me 这条主链路 100% 可测
真正卡住新手的,从来不是语法记不住,而是不知道哪个环节该做什么检查、哪个错误该在哪一层处理、哪个包该什么时候初始化。把上面任意一个项目从头敲一遍,跑通再删掉重写一次,比看十篇“Go 入门指南”管用得多。










