golang
已收录文章:13885篇
-
Go中的引用类型包括slice、map、channel、interface和func,它们赋值时共享底层数据而非复制。slice通过指向底层数组的指针实现引用语义,修改一个变量会影响另一个;map和channel同样具有引用特性,分别指向hmap结构和队列,赋值或传参仅复制指针,操作同一数据。指针(*)虽行为类似,但属于独立的指针类型,非引用类型。通常无需对引用类型使用指针,除非需在函数中修改slice本身或优化性能。190 收藏
-
Go语言中panic用于处理严重错误,触发后中断函数执行并沿调用栈回溯,直至程序崩溃或被recover捕获;recover必须在defer中调用,可拦截panic并恢复执行,常用于防止程序整体中断,如HTTP服务器兜底;但应优先使用error返回机制,panic仅限不可恢复错误,避免滥用以确保程序可维护性。198 收藏
-
答案:在Golang中,当读操作远多于写操作时,RWMutex因支持并发读而性能更优,适用于缓存、配置服务等场景;而读写频率相近或写操作频繁时,Mutex因开销更小反而更高效。RWMutex内部通过读锁计数和写锁互斥实现读写分离,但其复杂性带来额外开销,并可能引发写者饥饿问题,需根据实际读写比例和业务需求权衡选择。336 收藏
-
非缓冲channel需同步收发,发送和接收必须同时就绪,如ch:=make(chanint);缓冲channel可暂存数据,仅在缓冲满时发送阻塞、空时接收阻塞,如make(chanint,3),适用于解耦生产和消费。359 收藏
-
数组固定长度适合小数据,切片动态扩容更灵活;遍历和访问性能相近,但传参和扩容时切片更高效;建议小规模用数组,大规模及动态场景用切片并预设容量。420 收藏
-
答案:微服务错误处理需结合OpenTelemetry实现链路追踪,通过错误包装、Span记录、状态设置、上下文注入和状态码检查,确保错误可追溯;应设计统一错误码、传递上下文、实现重试与熔断、降级及监控告警机制,提升系统稳定性与问题定位效率。116 收藏