golang
已收录文章:12272篇
-
使用反射实现Golang的泛型容器,本质上是在牺牲性能的前提下提升代码灵活性和复用性。1.通过reflect包定义通用容器结构,使用reflect.Type和reflect.Value实现类型检查与元素操作;2.添加元素时进行类型匹配验证,确保运行时类型安全;3.获取元素需类型断言转换回具体类型,适用于基本类型和结构体;4.性能瓶颈在于反射的类型检查和转换开销,优化方法包括缓存类型信息、使用sync.Pool缓存reflect.Value、减少类型断言或采用代码生成;5.并发安全可通过引入sync.Mut463 收藏
-
Golang的reflect库允许在运行时检查和操作变量的类型与值,实现动态创建对象、调用方法及修改值等功能。1.使用reflect.New和reflect.NewAt可在运行时动态创建对象;2.通过reflect.Value.Method和reflect.Value.Call可动态调用方法;3.利用reflect.Value.Set系列方法可修改变量值,但需先检查CanSet;4.使用IsValid和CanSet避免panic错误;5.reflect.Type可用于获取结构体字段信息;6.反射性能较低,463 收藏
-
TLS握手优化通过减少客户端与服务器之间建立安全连接的时间,提升性能。1.SessionTicket允许客户端重用之前的会话信息,通过配置tls.Config启用SessionTicketKey实现;2.0-RTT允许客户端在握手完成前发送数据,需在TLS1.3及以上版本中启用EarlyDataHandler处理早期数据;3.安全方面,需定期轮换SessionTicket密钥以防止泄露,并防范0-RTT的重放攻击风险;4.可通过openssls_client命令测试SessionTicket是否生效,检查463 收藏
-
1.增加Channel容量和使用缓冲:通过增大channel的缓冲区来应对高并发流量,减少事件丢失风险;2.引入消息队列:采用RabbitMQ或Kafka等持久化消息队列,确保事件不因消费者离线而丢失;3.使用Goroutine池控制并发:借助semaphore包限制处理事件的goroutine数量,防止资源耗尽;4.实现重试机制:在事件发布失败后进行有限次数的重试,避免数据丢失;5.建立监控告警系统:实时监控channel拥堵情况并及时响应。这些策略可根据实际场景组合使用,以在高并发下有效防止事件丢失。463 收藏
-
背景 基于现在微服务或者服务化的思想,我们大部分的业务逻辑处理函数都是长这样的: 比如grpc服务端: func (s *Service) GetUserInfo(ctx context.Context, req *pb.GetUserInfoReq) (*pb.GetUserInfoRsp, error) { //462 收藏
-
1.什么是接口 接口就是一种规范与标准,在生活中经常见接口,例如:笔记本电脑的USB接口,可以将任何厂商生产的鼠标与键盘,与电脑进行链接。为什么呢?原因就是,USB接口将规范和标准制462 收藏