-
全量同步是Redis主从复制中从节点首次连接或断连超时后的兜底机制,通过PSYNC?-1触发,主节点执行BGSAVE生成RDB快照并缓存增量命令,再传输RDB及缓冲区命令完成数据一致。
-
正确使用Go指针需遵循:避免返回局部变量地址,如用new分配;控制共享范围,优先传值,必要时用Mutex保护;通过接口隐藏指针,如ReadOnly接口;设计不可变对象,如WithName返回新实例。核心是明确生命周期、控制共享、合理加锁、优先值传递。
-
Go语言通过reflect.TypeOf()和reflect.ValueOf()实现运行时类型检查与值操作,支持获取变量的类型信息(如名称、Kind)、结构体字段与标签、方法调用及动态修改值,广泛应用于序列化、ORM、RPC等场景,但需注意性能开销、类型安全和可设置性问题。
-
使用mock技术可避免真实数据库带来的环境复杂、速度慢等问题,通过gomock等工具模拟数据库行为,实现快速、稳定的单元测试。
-
time.Ticker无法做到高精度触发。它受Go调度、GC和系统调用影响,10ms周期偏差达2–8ms;5ms及以下不可控;适合粗粒度周期任务,不适用于硬实时场景;其无缓冲channel特性导致tick丢失,需校准时间或换用timerfd等方案。
-
make仅适用于slice、map、channel三种引用类型;因其设计目标是为运行时动态分配容量的类型创建并初始化实例,而数组和struct是编译期大小确定的值类型,无需make。
-
net/rpc要求方法签名严格合规:首字母大写的导出方法、指针接收者、Args和Reply参数、仅error返回值;需显式调用rpc.HandleHTTP()暴露HTTP接口;rpc.DialHTTP不支持context超时,易阻塞。
-
最靠谱方案是用etcd作为Golang分布式配置中心底座,因其成熟、轻量、云原生适配强,Kubernetes自身即依赖它;Consul和ZooKeeper的Go生态支持存在goroutine隐患与Watch语义不匹配问题。
-
Go敏感词过滤核心是防漏、防错、高并发稳定;DFA(前缀树)最实用,但需注意isEnd赋值位置、区分isEnd/isPrefix、用rune遍历、支持多匹配回溯、初始化childrenmap、中文替换用[]rune计数。
-
HTTP接口404是因为未调用RegisterXXXHandlerFromEndpoint注册路由;该函数必须在http.ListenAndServe前显式调用,且ctx不可提前cancel、endpoint需指向已启动的gRPC服务。
-
Go中复制文件最简洁高效的方式是用io.Copy配合os.Open和os.Create,自动流式拷贝、内存占用低;需错误处理与defer关闭,进阶可补充Chmod和Chtimes保留元信息。
-
直接用io.Copy将resp.Body写入*os.File是最安全高效的方式,因为绕过解码可避免失真、保全原始编码与元数据,并节省内存与CPU;而image.Decode→image.Encode不必要且易出错,仅在需图像处理时才适用。
-
在Go模板中,eq函数必须作为前缀操作符使用,不能写成(index$n0)eq(index$n1);正确写法是eq(index$n0)(index$n1),否则模板会因语法错误导致比较逻辑失效。
-
向量时钟是用于分布式系统中刻画事件偏序关系的整数数组,每个节点一个单调递增计数器,解决因果依赖与并发冲突判断;time.Time依赖物理时间,无法表达跨节点事件顺序,故Go中不能替代,需自定义VersionVector结构并确保节点有序、合并取最大值。
-
Go中用切片+sync.Pool实现无锁双端队列workerstealing:本地尾部入/出(LIFO),偷任务时头部截断(FIFO),避免竞争;需手动清空切片、控制cap、防止STW期间栈增长。