-
Go语言通过net包实现TCP和UDP编程,支持高性能网络服务。1.TCP通信:使用net.Listen监听端口,Accept接收连接,每个连接由goroutine处理,确保并发;客户端用net.Dial建立连接,收发数据后关闭。2.UDP通信:通过net.ListenPacket或net.DialUDP创建无连接服务,适用于低延迟场景,服务端读取数据包并回发响应。3.关键点:合理利用goroutine实现并发处理,妥善处理错误,及时释放资源,根据需求选择协议,正确使用IP:Port地址格式。Go的net
-
SetMaxOpenConns设得过大易压垮数据库,因超出DB默认连接上限(如MySQL151、PG100)会拒连,且大量空闲连接占用槽位并可能被DB超时kill,导致driver:badconnection;建议设为业务峰值并发的1.5–2倍且不超DBmax_connections的70%。
-
Go运行时强制检测map并发读写,必现panic;首选sync.RWMutex+原生map,因其泛型支持、高效遍历与可控锁粒度;sync.Map仅适用于键固定、读多写少等特定场景;开发期必须用-race定位竞态。
-
设计有上限、有退避、有幂等保护的重试策略。
-
syscall是性能瓶颈,因其涉及用户态/内核态切换、寄存器保存/恢复及权限检查等开销,高并发下显著拖慢吞吐;容器或云环境中该开销更明显。
-
strconv.Atoi仅支持十进制int转换,适用配置项等简单场景;strconv.ParseInt提供进制、位宽等完整控制,是健壮转换的首选。
-
测试数据工厂不能直接newstruct,因其导致字段硬编码、耦合难维护;应通过函数式选项模式封装默认值与灵活覆盖,隔离变化、确保可重入,并用延迟构建解耦关联结构。
-
应先调用FieldByName再检查IsValid()判断字段是否存在,因未导出或不存在的字段均返回无效值;FieldByName大小写敏感且仅支持导出字段,嵌套匿名字段需手动遍历。
-
channel阻塞和死锁源于生命周期、缓冲机制及协作逻辑理解偏差;发送与接收须成对且至少一方不阻塞;死锁是所有goroutine在channel操作上永久等待的确定状态;select+default可实现非阻塞操作。
-
Go语言允许编译器和处理器在单个goroutine内对无依赖的内存写入操作进行重排序,只要不改变该goroutine内部的语义;但若缺乏显式同步(如channel、mutex、atomic或sync.WaitGroup),其他goroutine可能观察到违反代码顺序的值更新。
-
通过reflect包可获取函数或方法的参数个数、类型及变参信息:先用reflect.TypeOf(函数)或reflect.ValueOf(实例).MethodByName("方法名").Type()得到类型对象,再调用NumIn()、In(i)和IsVariadic()解析参数结构,注意方法需导出且无法获取参数名。
-
本地队列优先被使用,因其是每个P独有、无锁的FIFO队列,存取零同步开销且缓存友好;满256时触发半队列迁移至全局队列以实现负载均衡;全局队列仅在本地空、窃取失败、系统调用返回或GC后等特定路径下才被访问。
-
Go中指针数组即[]T切片,需用make([]int,3)声明并显式初始化各元素,不可直接取切片元素地址以防悬垂指针;其内存开销通常大于值数组,仅在大结构体且需共享或部分修改时才有优势。
-
r.FormValue()是唯一可靠方法:它自动判断编码类型,multipart时调用ParseMultipartForm,普通表单时用ParseForm;r.PostFormValue()在multipart下总为空,因其只查未解析的空r.PostForm。
-
在Go中对结构体切片递归遍历并追加元素时,若直接对range循环变量取地址传入递归函数,会导致所有指针指向同一内存地址,造成数据污染和结果异常。