golang
已收录文章:290篇
-
空接口(interface{})是Go语言实现多态和泛型编程的核心手段,允许处理任意类型数据,但需运行时类型断言,牺牲部分类型安全与性能。它通过类型断言和类型开关实现对异构数据的动态处理,广泛应用于JSON解析、通用函数、事件系统、配置管理等场景。在Go1.18引入泛型后,泛型成为处理同构类型、需编译时类型安全和高性能场景的首选,而interface{}仍适用于真正异构或动态性要求高的场景,两者互补共存。438 收藏
-
Go语言的goroutine调度机制通过M:N模型将大量goroutine映射到少量OS线程,由G-P-M结构管理,GOMAXPROCS决定P的数量,默认等于CPU核数,M绑定P执行G,G阻塞时P可与新M绑定以保持并行,用户态切换降低开销,异步抢占保障公平性,但过多goroutine或锁竞争仍会导致调度开销与缓存失效,影响CPU利用率;优化策略包括合理使用WorkerPool控制并发数、避免阻塞操作、减少锁竞争、利用sync/atomic和pprof分析CPU、Block、Mutex及Trace数据定位调314 收藏
-
全局变量在函数外声明,作用域覆盖整个包,首字母大写可被外部包访问,如GlobalCounter;小写则仅限包内使用,如appName。它们在main函数前初始化,支持var()块集中声明和init()函数进行复杂初始化设置。建议避免过度使用可变全局变量以减少耦合与并发风险,优先通过参数传递依赖,配置类数据宜封装结构体并提供访问方法,提升代码可控性与可维护性。422 收藏
-
Go语言通过net包和goroutine实现高效网络编程,支持TCP/UDP通信。1.使用net.Listen创建TCP服务器,Accept接收连接,每个conn由独立goroutine处理,实现高并发;2.TCP客户端用net.Dial连接服务端,通过bufio读写数据,实现双向通信;3.UDP通过ListenUDP和DialUDP进行无连接通信,适用于低延迟场景;4.关键实践包括:利用goroutine轻量处理连接、设置读写超时、defer关闭资源、解决TCP粘包问题。Go的简洁语法与并发模型使其非常177 收藏
-
使用Protobuf定义Go接口需先编写.proto文件描述服务与消息,再通过protoc生成Go代码。示例中定义UserService服务及GetUser方法,包含请求响应消息结构;安装protoc-gen-go和protoc-gen-go-grpc插件后执行编译命令,生成user.pb.go和user_grpc.pb.go文件;服务端实现UserServiceServer接口并注册服务,客户端通过NewUserServiceClient调用远程方法。整个流程标准化,提升通信效率与契约一致性,适合微服务170 收藏
-
Go语言通过crypto/tls包实现安全通信,使用ListenAndServeTLS启动HTTPS服务器需配置证书和私钥;建议自定义tls.Config以禁用旧版本、启用强加密套件,并通过http.Transport配置客户端证书验证,生产环境应避免InsecureSkipVerify,使用可信CA签发证书确保安全。104 收藏