-
json.Unmarshal不返回解析结果,只返回error;必须传结构体指针,字段需大写且合理使用jsontag;null设零值或nil,缺失字段不修改,类型不匹配则跳过。
-
GoGC性能问题根源在于内存分配行为而非参数调优,应通过gotooltrace分析GC节奏、pprof-alloc_space定位高频分配源,并优化逃逸、减少隐式拷贝、合理使用sync.Pool。
-
应使用errors.Is或errors.As判断错误类型,避免直接比较error字符串;封装断言函数区分“必须无错”和“必须有特定错”;注意错误链完整性、堆栈可见性及Error()字符串的脆弱性。
-
atomic.AddInt64与mutex.Lock/Unlock基准测试需拆分为独立函数,各自使用隔离变量、预重置值、仅含核心操作;atomic.LoadInt64读快于RWMutex.RLock但无读-判-写原子性;高争用下falsesharing会导致atomic反而更慢,需填充缓存行。
-
selectcase的求值顺序是随机的,Go运行时会先对所有case的通信操作进行求值,再随机选择一个可执行的case执行,而非按代码书写顺序从上到下依次判断。
-
colly.NewCollector()初始化抓不到页面主因是默认禁用JS渲染且未设UserAgent或处理重定向;需显式设置UserAgent、开启AllowURLRevisit、用AbsoluteURL转相对链接、控制并发并加Delay,CSV保存需加BOM头防乱码。
-
模拟依赖通过接口和依赖注入实现,提升测试效率与稳定性。定义接口后创建模拟对象,注入被测单元以隔离外部系统,避免真实依赖带来的速度慢、不稳定等问题。手动模拟适用于简单场景,第三方库如testify/mock或GoMock适合复杂接口。需避免过度模拟,确保模拟行为与真实一致,结合集成测试验证系统协同。
-
最简单可控的高亮方案是regexp.ReplaceAllStringFunc配合HTML标签包裹关键词,但需先用regexp.QuoteMeta转义元字符以防panic;strings.ReplaceAll因仅支持字面替换、无法区分独立词与子串、不支持忽略大小写及跨行匹配而不可用。
-
不能直接用int当计数器,因非原子操作会导致竞态——counter++在汇编层为读-改-写三步,多goroutine并发时结果必然不可靠;必须用sync.Mutex或sync/atomic,后者要求显式使用uint64等对齐类型并配对Load/Store/Add操作。
-
goroutine泄漏是并发性能下降的头号原因,表现为Mallocs持续上涨、Goroutines数卡在高位;常见于time.After轮询未改用Timer.Reset,以及channel读写不配对导致阻塞。
-
Go公共工具包本质是跨模块复用的契约,需保障向后兼容、清晰语义与可控副作用;路径须独立稳定(如github.com/yourorg/go-tools),按领域拆分子包,函数无隐式状态,错误类型结构化且不panic。
-
优化Golang项目启动性能需减少init函数冗余操作、控制依赖顺序并拆分逻辑。1.避免在init中执行HTTP请求、数据库连接等耗时操作,应延迟到首次使用时执行;2.合理组织初始化顺序,避免跨包依赖,改用接口或懒加载解耦,手动调用注册函数替代自动注册;3.拆分init逻辑,使用sync.Once实现按需初始化,降低启动负载;4.减少init数量,将复杂逻辑封装为普通函数,在main中显式调用以提升可维护性。滥用init会导致性能瓶颈与结构混乱,关键在于识别非必要初始化并清晰组织流程。
-
Go禁止import循环是因编译期需确定初始化顺序和符号可见性,强制接口解耦、职责分离;常用解法包括提取公共接口到第三方包、使用internal隔离共享逻辑、延迟初始化及函数注入依赖。
-
GoConvey和Testify根本不是同一类工具GoConvey是一个带WebUI的测试运行器+断言库,Testify是纯断言(assert/require)和模拟(mock)工具包。很多人误以为它们是“二选一”的测试框架,其实你在用gotest时完全可以同时用testify/assert+goconvey——前者管断言逻辑,后者管执行和展示。常见错误现象:goconvey启动后页面空白、测试不自动刷新,往往是因为没在项目根目录运行,或goconvey找
-
sliceHeader是Go运行时内部描述切片的非公开结构体,含data、len、cap字段;直接操作会绕过内存安全机制,导致GC异常、越界或未定义行为,应使用unsafe.Slice等安全替代方案。