-
Go面试考内存模型核心是逃逸分析:变量逃逸看“escapestoheap”,闭包捕获、返回地址、interface{}传参、切片扩容等均导致逃逸;栈归goroutine管,堆归GC管;高频逃逸加重GC压力,需用sync.Pool、预估容量等优化。
-
%v和%+v的区别在于:对结构体,%v仅输出字段值如{123"hello"},%+v输出带字段名的格式如{A:123B:"hello"};对map、slice等其他类型二者行为完全相同。
-
Go多核性能瓶颈主因是GOMAXPROCS配置失当、I/O阻塞未卸载及goroutine泄漏;需检查同步I/O、全局锁争抢、LockOSThread误用,并用trace/pprof定位调度问题。
-
Go函数签名中参数顺序不可调换,因顺序是类型的一部分;空参数或返回列表必须保留括号;error虽非语法强制置末位,但属关键约定,影响工具链、泛型匹配与第三方库兼容性。
-
Trivy扫描Go静态二进制需强制启用文件系统扫描、注入go.mod.json并避开挂载点;OOMKilled根源是cgroupv1与Go内存统计错位;eBPFtrace断链因用户态与内核态上下文未桥接。
-
不能。标准http.ServeMux仅支持前缀和完全匹配,不解析路径参数如/user/123中的123;注册/user/{id}会导致404,需手动解析或改用gorilla/mux等第三方库。
-
Go匿名函数无名但可赋值、立即调用或传参,语法为func(参数)返回类型{函数体};闭包捕获外部变量引用而非值拷贝,易致变量共享陷阱。
-
本地包路径必须以./或../开头,不可用裸名称;同模块内子目录包自动识别,无需写入go.mod;避免循环导入,测试时注意工作目录影响资源定位。
-
需先用reflect.TypeOf()获取类型再调.Kind()判断是否等于reflect.Map,且必须前置检查接口值非nil,否则reflect.TypeOf(nil)返回nil导致panic。
-
RabbitMQ生产者发不出消息,需检查amqp.Publishing的exchange和routingkey是否为空;消费者panic导致消息重复,须关闭autoAck并手动Ack;JSON序列化失败常因字段未导出或tag拼写错误;服务重启后消息堆积,应复用连接/Channel并设置上下文超时。
-
最简HTTP服务只需调用http.ListenAndServe(":8080",nil),它使用默认多路复用器http.DefaultServeMux,注册路由须用http.HandleFunc且第二个参数为nil;端口格式必须是":8080"字符串,监听地址推荐"0.0.0.0:8080"以支持外部访问。
-
Go的并发内存模型通过“happens-before”原则确保操作的可见性和顺序。1.同一个goroutine中代码顺序即happens-before顺序;2.channel发送happens-before接收;3.Mutex.Unlockhappens-before下一次Lock;4.sync.Once保证初始化完成前的操作对所有后续访问可见;5.原子操作提供同步保障。若未显式建立该关系,则可能因重排导致行为不确定。
-
核心是控制并发规模而非盲目启goroutine;用带缓冲chan作信号量(如sem:=make(chanstruct{},10))限制同时活跃worker数,避免瞬间启动过多goroutine导致DNS耗尽、连接超时或429错误。
-
本文详解Gotext/template中如何在单条if语句中组合多个布尔条件(如“$total==1且has()返回false”),澄清管道|的参数传递机制,纠正常见误用,并提供可运行的语法范式与注意事项。
-
Go用net/http和html/template实现后台管理页,服务端渲染HTML,配合轻量前端交互完成CRUD,需手动处理路由、数据绑定与错误提示。