
golang
因为Go中数组是值类型,传参时会复制整个数组,函数内修改不影响原数组;需用数组指针(*[3]int)或切片([]int)才能修改原数据。
time.Ticker适合固定间隔轮询但不保证准时,仅确保两次Tick()调用间隔指定时间;任务超时会导致延迟累积或跳过tick,适用于健康检查等低精度场景,不适用于金融结算等严格定时场景。
能提升性能,但仅在明确元素数量且一次性写入时有效;预分配可避免多次扩容重哈希,实测批量初始化快20%–40%,而小规模、渐进插入等场景无效甚至浪费内存。
不用自增ID做短码因会暴露业务数据、难以并发预知ID,需解耦;推荐随机+重试或雪花ID派生,Go+SQLite用INSERTONCONFLICT避免竞态。
Go1.20引入errors.Join作为官方推荐的多错误聚合标准方式,支持嵌套、去重、nil忽略及完整errors.Is/As兼容性,取代字符串拼接和自定义MultiError。
选gin而非net/http:路由分组、中间件、JSON绑定开箱即用且性能不输;net/http仅适用于极简场景或协议层调试;务必设超时与优雅退出,结构体JSON字段需显式tag。
滥用panic本质是错误处理权错配;该用error而非panic的核心判断是调用方能否/应否响应失败:能则返回error,不能且继续执行会致状态污染才考虑panic。
Go的regexp.MatchString仅返回是否匹配的布尔值,不提取内容;需用FindString、FindStringSubmatch等函数获取匹配文本或分组。
Go数组是固定长度的连续内存块,长度属于类型签名,[3]int与[5]int类型不兼容;声明必须指定长度,...仅用于字面量推导;越界访问会panic。
正确姿势是用os.OpenFile配合os.O_APPEND|os.O_WRONLY|os.O_CREATE标志,确保原子性追加;避免单独使用O_APPEND、误加O_TRUNC或用os.Seek+W...