go 常见面试题

一、基础语法与类型

  1. Go 与 C/Java 有哪些主要区别?

  2. Go 的数据类型有哪些?值类型和引用类型分别是什么?

  3. nilzero value 的区别?

  4. 切片(slice)、数组(array)、map 的底层实现原理是什么?

  5. defer 的执行时机和使用场景?

  6. 指针在 Go 中的使用限制?Go 不允许指针运算的原因?

  7. newmake 的区别?


二、控制流与函数

  1. Go 如何实现可变参数函数?

  2. 闭包(closure)的原理和使用场景?

  3. panicrecovererror 的区别和使用场景?

  4. 方法(method)与函数(function)的区别?

  5. 值接收者与指针接收者的区别?


三、并发与调度

  1. Goroutine 是什么,如何创建?

  2. runtime.Gosched()runtime.Goexit()time.Sleep() 的区别?

  3. channel 的类型、缓冲与非缓冲区别?

  4. select 多路复用的原理?

  5. 如何避免 channel 死锁?

  6. sync.Mutexsync.RWMutexsync/atomic 的区别?

  7. WaitGroup 的作用与使用方法?

  8. 如何限制并发数量(例如线程池)?

  9. Goroutine 泄漏的场景及排查方法?


四、内存管理

  1. Go 的内存分配策略(栈 vs 堆)?

  2. 垃圾回收(GC)机制是什么?

  3. 指针逃逸分析(escape analysis)是什么?

  4. slice 扩容(append)的原理?

  5. map 底层实现原理(哈希表 + 冲突处理)?


五、接口与面向对象

  1. Go 如何实现面向对象?

  2. 接口(interface)是什么,如何使用?

  3. 空接口(interface{})的用途?

  4. 类型断言和类型转换的区别?

  5. Go 中没有继承,如何实现多态?


六、标准库与工具

  1. Go 的包管理方式(module、GOPATH)?

  2. context.Context 的作用?

  3. net/http 与 fasthttp 的区别?

  4. Go 内置日志包 log 的特点?

  5. reflect 包的使用场景和性能问题?


七、性能与优化

  1. 如何分析 Go 程序性能瓶颈?

  2. pprof 的使用方法?

  3. 内存泄漏、Goroutine 泄漏的排查方法?

  4. 大量小对象频繁创建对 GC 的影响?


八、实战类/场景题

  • 用 Go 实现一个限流器(Token Bucket/Leaky Bucket)

  • 用 Go 实现一个线程安全的缓存

  • 并发下载文件/数据聚合

  • 实现一个生产者-消费者模型

  • 实现一个简单的协程池(Goroutine Pool)

  • 用 channel 实现奇偶交替输出(面试常考)

相关推荐
uzong4 分钟前
半小时打造七夕传统文化网站:Qoder AI编程实战记录
后端·ai编程
快乐就是哈哈哈8 分钟前
从传统遍历到函数式编程:彻底掌握 Java Stream 流
后端
chenglin0169 分钟前
Logstash_Input插件
java·开发语言
3壹19 分钟前
单链表:数据结构中的高效指针艺术
c语言·开发语言·数据结构
不过普通话一乙不改名1 小时前
第四章:并发编程的基石与高级模式之Select语句与多路复用
开发语言·golang
ningqw1 小时前
JWT 的使用
java·后端·springboot
追逐时光者2 小时前
精选 2 款 .NET 开源、实用的缓存框架,帮助开发者更轻松地处理系统缓存!
后端·.net
JCBP_2 小时前
QT(1)
开发语言·汇编·c++·qt
可峰科技2 小时前
qt配置ros2环境,简单版本
开发语言·qt
David爱编程2 小时前
指令重排与内存屏障:并发语义的隐形守护者
java·后端