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

golang
golang专题下共有 983 篇文章
  • Golang责任链模式中间件怎么实现
    Golang责任链模式中间件怎么实现
    责任链模式是一种将请求沿处理链传递的设计模式,Golang中可通过中间件方式实现。1.定义中间件函数类型funcMiddleware(http.Handler)http.Handler;2.通过手动嵌套或切片链式组装构建处理链;3.中间件按顺序包装处理器,每个节点决定是否继续执行;4.典型应用场景包括日志记录、身份验证、限流控制等;5.注意事项包括中间件顺序、中断处理、上下文传递及性能优化。
    Golang· Go教程   |  2星期  |   golang 中间件 责任链模式 http.Handler 处理链 199浏览 收藏
  • GolangRPC框架为何受欢迎?gRPC与JSON-RPC对比解析
    GolangRPC框架为何受欢迎?gRPC与JSON-RPC对比解析
    Golang的RPC框架在微服务中流行的核心原因在于其简洁高效、与高并发优势结合,能快速构建高性能系统。gRPC相比JSON-RPC性能更高,1.使用ProtocolBuffers作为二进制协议,序列化更快体积更小;2.基于HTTP/2支持多路复用和头部压缩;3.自动生成客户端和服务端代码减少人工错误。选择RPC框架需考虑:1.对性能要求高且接口稳定时选gRPC;2.项目简单或需集成非gRPC服务时选JSON-RPC;3.团队技术栈影响学习成本。其他值得关注的GolangRPC框架包括:Thrift跨语言
    Golang· Go教程   |  5天  |   golang grpc 微服务 RPC框架 JSON-RPC 198浏览 收藏
  • Golang测试捕获panic方法:recover与实战技巧
    Golang测试捕获panic方法:recover与实战技巧
    要验证Go函数中是否触发panic,可使用defer和recover机制捕获并验证。具体步骤如下:1.在测试函数中定义defer语句,并在其中调用recover()以捕获panic;2.设置标志位或直接判断recover返回值是否为nil来确认是否发生panic;3.若需多次使用,可封装辅助函数assertPanic简化逻辑;4.如需验证panic内容,可进一步扩展封装函数以检查具体的错误信息。通过这种方式,可以有效测试预期的panic行为,同时保持代码简洁和可维护性。
    Golang· Go教程   |  2天  |   golang defer recover panic Testing 198浏览 收藏
  • Golang解析复杂协议,手动解码二进制数据
    Golang解析复杂协议,手动解码二进制数据
    解析二进制数据流需明确协议结构并按顺序处理字段。1.先确定协议格式,如头部、长度标识、校验和等;2.使用bytes.Buffer和binary.Read按字节序逐个读取字段;3.对变长字段结合长度信息提取数据内容;4.嵌套结构可重构buffer继续解析;5.字符串等特殊类型使用buf.Next提取;6.错误处理需区分EOF与其他异常;7.每步读取前检查剩余缓冲区长度防止越界。
    Golang· Go教程   |  2星期  |   golang bytes.Buffer 二进制数据流 binary.Read 协议解析 197浏览 收藏
  • FreeRTOS运行Golang:嵌入式配置教程
    FreeRTOS运行Golang:嵌入式配置教程
    在FreeRTOS中运行Golang需通过交叉编译将Go代码转为C兼容静态库并集成至项目。1.使用cgo进行交叉编译,生成C语言静态库libgo.a及头文件main.h;2.搭建FreeRTOS开发环境,包括编译器、IDE和调试工具;3.将生成的库文件集成到FreeRTOS项目中,并修改构建脚本以链接库文件;4.禁用Go垃圾回收,手动管理内存,并使用FreeRTOS任务模拟goroutine并发;5.调试时使用GDB或日志输出观察执行结果;6.优化性能,减少内存分配、选择高效算法、启用编译优化、避免反射;
    Golang· Go教程   |  4天  |   golang CGO 交叉编译 静态库 FreeRTOS 197浏览 收藏
  • Golang零拷贝优化:io.Copy与sendfile详解
    Golang零拷贝优化:io.Copy与sendfile详解
    io.Copy默认使用中间缓冲区导致多次内存拷贝,而sendfile可实现零拷贝。io.Copy默认使用32KB缓冲区在用户空间中转数据,造成文件内容从磁盘到用户空间再到socket的多次复制;sendfile系统调用则直接在内核态完成文件传输,跳过用户空间,降低CPU和内存开销;Go标准库如net/http在静态文件服务等条件下会自动使用sendfile;手动触发可通过syscall.Sendfile实现,但需满足源为普通文件、目标支持sendfile等条件;适用场景包括大文件传输、静态资源服务和高并发
    Golang· Go教程   |  1天  |   golang 性能优化 io.Copy 零拷贝 sendfile 197浏览 收藏
查看更多
课程推荐
  • 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通道如何传递数据,反射等等。
    128次学习
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码