当前位置:首页 > 文章列表 >golang

golang
golang专题下共有 12283 篇文章
  • 如何优化golang框架中的性能监控开销?
    如何优化golang框架中的性能监控开销?
    为了优化Go框架中的性能监控开销:选择低开销的库,例如expvar、pprof或uber-go/automax。优化监控间隔,仅在必要时收集数据。使用采样,仅收集部分数据以减少开销。异步收集指标数据,避免阻塞应用程序。缓存指标值以避免重复计算。
    Golang· Go教程   |  1年  |   golang 性能监控 463浏览 收藏
  • Golang错误处理测试技巧与方案
    Golang错误处理测试技巧与方案
    在Golang中测试错误处理代码,需验证函数是否返回正确错误并妥善处理后续状态。主要策略包括:1.构造特定输入使函数进入错误分支;2.使用errors.Is或errors.As判断错误类型与信息;3.检查错误后程序状态是否正常回滚;4.采用表格驱动测试覆盖多种场景。例如,通过模拟除零错误验证错误信息,或用mock框架模拟数据库连接失败等复杂错误。errors.Is用于匹配错误链中的目标错误,errors.As则用于将错误转为具体类型以访问其字段。借助代码覆盖率工具如gotest-coverprofile可
    Golang· Go教程   |  2个月  |   golang 错误处理 463浏览 收藏
  • 反射实现Golang泛型容器,安全集合操作详解
    反射实现Golang泛型容器,安全集合操作详解
    使用反射实现Golang的泛型容器,本质上是在牺牲性能的前提下提升代码灵活性和复用性。1.通过reflect包定义通用容器结构,使用reflect.Type和reflect.Value实现类型检查与元素操作;2.添加元素时进行类型匹配验证,确保运行时类型安全;3.获取元素需类型断言转换回具体类型,适用于基本类型和结构体;4.性能瓶颈在于反射的类型检查和转换开销,优化方法包括缓存类型信息、使用sync.Pool缓存reflect.Value、减少类型断言或采用代码生成;5.并发安全可通过引入sync.Mut
    Golang· Go教程   |  2个月  |   golang 泛型容器 463浏览 收藏
  • Golang反射库高级技巧详解
    Golang反射库高级技巧详解
    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.反射性能较低,
    Golang· Go教程   |  1个月  |   golang 动态 元编程 reflect 运行时 463浏览 收藏
  • GolangTLS优化:0-RTT与SessionTicket配置详解
    GolangTLS优化:0-RTT与SessionTicket配置详解
    TLS握手优化通过减少客户端与服务器之间建立安全连接的时间,提升性能。1.SessionTicket允许客户端重用之前的会话信息,通过配置tls.Config启用SessionTicketKey实现;2.0-RTT允许客户端在握手完成前发送数据,需在TLS1.3及以上版本中启用EarlyDataHandler处理早期数据;3.安全方面,需定期轮换SessionTicket密钥以防止泄露,并防范0-RTT的重放攻击风险;4.可通过openssls_client命令测试SessionTicket是否生效,检查
    Golang· Go教程   |  1个月  |   golang TLS优化 SessionTicket 0-RTT tls.Config 463浏览 收藏
  • GolangChannel实现事件发布订阅系统
    GolangChannel实现事件发布订阅系统
    1.增加Channel容量和使用缓冲:通过增大channel的缓冲区来应对高并发流量,减少事件丢失风险;2.引入消息队列:采用RabbitMQ或Kafka等持久化消息队列,确保事件不因消费者离线而丢失;3.使用Goroutine池控制并发:借助semaphore包限制处理事件的goroutine数量,防止资源耗尽;4.实现重试机制:在事件发布失败后进行有限次数的重试,避免数据丢失;5.建立监控告警系统:实时监控channel拥堵情况并及时响应。这些策略可根据实际场景组合使用,以在高并发下有效防止事件丢失。
    Golang· Go教程   |  1个月  |   golang channel 高并发 发布订阅模式 事件系统 463浏览 收藏
查看更多
课程推荐
  • Golang深入理解GPM模型
    Golang深入理解GPM模型
    Golang深入理解GPM调度器模型及全场景分析,希望您看完这套视频有所收获;包括调度器的由来和分析、GMP模型简介、以及11个场景总结。
    474次学习
  • Go语言课程Gin框架实战
    Go语言课程Gin框架实战
    Gin是一个用Go(Golang)编写的HTTPweb框架。它是一个类似于 martini 但拥有更好性能的API框架,由于 httprouter,速度提高了近40倍。如果你需要极好的性能,使用Gin吧。
    338次学习
  • Golang云原生架构师课程
    Golang云原生架构师课程
    Go是一门并发支持、垃圾回收的编译型系统编程语言;本课程转载自哔哩哔哩:https://www.bilibili.com/video/BV1Mh411M7A
    204次学习
  • Go编程基础视频教程
    Go编程基础视频教程
    Go是一门并发支持、垃圾回收的编译型系统编程语言,旨在创造一门具有在静态编译语言的高性能和动态语言的高效开发之间拥有良好平衡点的一门编程语言。我们收集了这套《Go编程基础视频教程》,希望能够帮助大家更好的学习go语言。
    167次学习
  • Golang进阶实战编程
    Golang进阶实战编程
    本课程是在《Go语言基础视频》基础之上录制的,是Go语言基础的后半部分。包括包的管理,IO操作,Go语言最大的亮点:高并发,goroutine,channel,反射等。本视频主要为了帮助Go语言的初学者,从零到一的快速入门。学完本套课程,可以学会如果通过包管理Go项目,并发模型,以及并发实现,channel通道如何传递数据,反射等等。
    129次学习
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码