-
双指针是用两个索引变量协同遍历的思路,非Go语法特性;快慢指针适用于有序去重、链表环检测等依赖速度差的场景,对撞指针适用于两数之和、回文判断等依赖两端收缩的场景。
-
用Golang做站点可用性检测需并发控制、健壮HTTP客户端、分层结果判定及可靠上报:通过workerpool限并发,自定义http.Client设超时与连接复用,按网络/协议/业务层分类错误,耗时超阈值标记为慢或不可用,结果异步批量上报并本地落盘重试。
-
Go性能优化需减少变量逃逸,核心是让变量留在栈上。常见逃逸场景包括:返回局部变量指针、闭包捕获、赋值给interface{}、goroutine传参指针。使用gobuild-gcflags="-m"可检测逃逸。优化策略有:避免返回指针、调整结构体字段顺序以减少内存对齐开销、减少指针成员、复用对象或使用sync.Pool降低GC压力。
-
生产环境必须显式构造带超时和连接复用的http.Client,禁用http.Get;需设Timeout、MaxIdleConnsPerHost,并始终Closeresp.Body;JSON解析应先ReadAll再Unmarshal。
-
短链接系统需避免哈希碰撞、保障跳转性能、防御刷量并优化统计:用带盐的SHA256+重试生成7位短码;跳转走sync.Map+Redis双层缓存,5ms内完成;限流前置至Nginx和Go服务;统计异步聚合写入Kafka/ClickHouse。
-
使用os/exec包执行系统命令,通过exec.Command创建命令对象并调用Run()等待完成;2.用Output()获取命令输出;3.手动设置Stdin、Stdout、Stderr以控制输入输出流;4.设置Env字段传递环境变量;5.避免拼接用户输入防止命令注入。
-
Go1.21+是Web开发合理起点,需验证版本、GOPATH/GOBIN配置,用gomodinit初始化模块,优先原生net/http实践再选框架,搭配fresh热重载与curl/gotooltrace调试。
-
Go中optional字段生成带指针类型(如string、int32),用于区分“未设置”和“设为空值”,读取需判空后解引用,设置需取地址,清空赋nil,不支持default,JSON中null→nil、""→指向空字符串。
-
用net/http启动投票服务需按HTTP方法拆分路由,POST/vote处理投票,GET/results返回统计;用sync.Map或SQLite持久化计票结果;注意防重复提交、内容类型校验、超时控制及日志记录。
-
JSON字段为null时,string类型字段解码后是零值"";需区分null与空字符串时必须用*string,解码后null→nil、""→指向空字符串的指针,取值前须判空防panic。
-
使用互斥锁或通道控制并发文件读写,避免竞态条件;通过errors.Is分类处理错误,确保数据安全与程序稳定。
-
值类型传参复制数据,函数内修改不影响原值;指针类型传参传递地址,可修改原始变量。例如,int值传递不改变原值,而int通过x=100可更新原变量。结构体较大时,指针传递避免复制开销并支持字段修改,如Person结构体使用指针参数提升效率与可变性。选择依据为是否需修改原值及数据大小,注意避免指针滥用导致意外修改。
-
TCP长连接不应加应用层重传,因内核已实现完整可靠传输机制;盲目重传会导致重复、错序和状态不一致,仅在协议要求“至少一次送达”且服务端幂等时才可引入。
-
<p>Go中匿名函数需赋值给变量或立即执行,语法为fn:=func(xint)int{returnx*2}或func(){fmt.Println("hello")}(),支持闭包但需警惕循环中捕获迭代变量的陷阱。</p>
-
Go微服务错误需显式分类处理:BusinessError含Code/Message/HTTPStatus,SystemError含TraceID/cause/操作建议;统一映射gRPC与HTTP错误;包装错误用%w但生产环境须脱敏;所有错误传播必须响应context超时与cancel。