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

golang
golang专题下共有 11823 篇文章
  • Golang单例实现:sync.Once与atomic对比
    Golang单例实现:sync.Once与atomic对比
    在Golang中实现并发安全的单例模式,sync.Once适合初始化短耗时和低并发场景,atomic适合高并发且需极致性能的场景。1.sync.Once方案简单易用,通过互斥锁保证初始化仅执行一次,但存在锁竞争和首次获取阻塞的问题;2.atomic方案利用CAS操作避免锁,理论上性能更优,但实现复杂且初始化耗时无法并行;3.选择方案应基于实际场景:初始化短且并发低时优先使用sync.Once,初始化长且并发高时考虑atomic,但需充分测试验证性能提升和安全性。
    Golang· Go教程   |  1星期  |   golang 对比 sync.Once 并发单例 atomic 153浏览 收藏
  • Golang高并发文件写入优化技巧
    Golang高并发文件写入优化技巧
    使用os.OpenFile配合sync.Mutex可实现并发安全的文件写入,具体操作如下:1.打开文件时使用os.O_CREATE|os.O_APPEND|os.O_WRONLY标志确保正确写入模式;2.使用sync.Mutex在写入时加锁以避免goroutine间冲突;3.结合bufio.Writer缓冲写入或批量合并减少I/O次数以提升性能;4.注意定期flush缓存及调用file.Sync()强制刷盘以防止数据丢失;5.始终使用deferfile.Close()关闭文件并妥善处理错误和重试机制。
    Golang· Go教程   |  1星期  |   golang 高性能 sync.Mutex 文件并发写入 os.OpenFile 329浏览 收藏
  • Golang指针运算限制对比C语言解析
    Golang指针运算限制对比C语言解析
    Golang限制指针运算是为了提升代码安全性与可维护性,具体方式包括:1.不支持指针加减运算,防止越界访问;2.禁止不同类型的指针转换,除非使用unsafe包;3.依赖自动垃圾回收机制避免悬挂指针;4.强类型检查减少类型不匹配错误。虽然牺牲了一定灵活性,但通过切片、映射等结构保障了内存操作的安全性,并提升了程序可靠性与可读性。
    Golang· Go教程   |  1星期  |   golang C语言 限制 安全设计 指针运算 429浏览 收藏
  • Golang自动部署指南:用ArgoCD实现GitOps流程
    Golang自动部署指南:用ArgoCD实现GitOps流程
    为Golang应用配置自动化部署并借助ArgoCD实现GitOps工作流,核心在于将应用与基础设施的声明性配置存储于Git仓库中,由ArgoCD持续监控并同步集群状态至Git定义的状态。1.首先容器化Golang应用,编写Dockerfile构建镜像并推送至镜像仓库;2.创建Kubernetes清单(Deployment、Service等),推荐使用Kustomize或Helm进行参数化管理;3.将K8s配置文件提交至Git仓库作为配置源;4.安装ArgoCD并在其中创建Application资源指向该G
    Golang· Go教程   |  1星期  |   golang Kubernetes 自动化部署 GitOps ArgoCD 257浏览 收藏
  • 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 492浏览 收藏
  • GolanggRPC对比REST性能解析
    GolanggRPC对比REST性能解析
    要使用Golang开发gRPCWeb服务,需定义gRPC服务并生成Go和JavaScript代码;接着配置gRPC-Web代理(如grpc-web或Envoy)将HTTP/1.1请求转换为gRPC请求;最后通过HTTP服务器代理gRPC-Web请求。具体步骤如下:1.使用protoc编译protobuf文件生成服务端和客户端代码;2.安装protoc-gen-grpc-web插件并配置protobuf文件;3.创建HTTP反向代理服务器处理请求;4.处理流式传输时,gRPC-Web支持服务端和客户端流式模
    Golang· Go教程   |  1星期  |   golang 性能 grpc rest gRPCWeb 258浏览 收藏
查看更多
课程推荐
  • 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次学习
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码