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

golang
golang专题下共有 13974 篇文章
  • Golang单例实现:sync.Once与atomic对比
    Golang单例实现:sync.Once与atomic对比
    在Golang中实现并发安全的单例模式,sync.Once适合初始化短耗时和低并发场景,atomic适合高并发且需极致性能的场景。1.sync.Once方案简单易用,通过互斥锁保证初始化仅执行一次,但存在锁竞争和首次获取阻塞的问题;2.atomic方案利用CAS操作避免锁,理论上性能更优,但实现复杂且初始化耗时无法并行;3.选择方案应基于实际场景:初始化短且并发低时优先使用sync.Once,初始化长且并发高时考虑atomic,但需充分测试验证性能提升和安全性。
    Golang· Go教程   |  5个月  |   golang 线程安全 sync.Once 并发单例 atomic 364浏览 收藏
  • Golang实现简单HTTP代理教程
    Golang实现简单HTTP代理教程
    Golang制作简易HTTP代理需监听端口接收请求并转发。1.创建HTTP服务器,监听指定端口,接收客户端请求;2.修改请求头、URL等信息,若URL无Scheme默认使用http,处理无Host情况并返回错误;3.使用http.NewRequest创建请求,复制原始请求头,通过http.Client发送至目标服务器;4.处理响应头、状态码及响应体,将其返回客户端。代码中加入对错误的处理,并将错误码设为StatusBadGateway以符合代理场景。处理HTTPS请求时需配置TLSClientConfig
    Golang· Go教程   |  5个月  |   golang HTTP代理 websocket net/http 请求转发 259浏览 收藏
  • Golang随机密码生成方法与工具推荐
    Golang随机密码生成方法与工具推荐
    要自定义密码字符集以满足特定安全需求,需修改charSet变量内容。例如,若仅需字母和数字,可设置charSet为"abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";如需进一步灵活配置,可通过配置文件或环境变量读取字符集。同时,需在安全性与易用性之间取得平衡,确保字符集足够丰富但不过于复杂。
    Golang· Go教程   |  5个月  |   golang 安全策略 字符集 crypto/rand 随机密码生成 365浏览 收藏
  • GolangAPI错误处理与重试实现方案
    GolangAPI错误处理与重试实现方案
    调用第三方API时构建具备重试机制的HTTP客户端可提升稳定性。1.控制重试次数,一般设为2~3次;2.设置合理间隔时间,建议使用指数退避策略;3.区分可重试与不可重试错误,如网络超时、连接失败和5xx错误可重试,4xx和TLS握手失败通常不重试;4.使用自定义RoundTripper实现重试逻辑,在每次请求失败后判断错误类型并决定是否重试;5.结合context.Context控制超时,记录日志以便排查问题;6.封装成通用组件便于复用,提供默认配置同时支持自定义参数。通过这些策略,能有效增强程序的健壮性
    Golang· Go教程   |  5个月  |   golang 错误处理 HTTP客户端 重试机制 API调用 349浏览 收藏
  • WindowsTerminal优化Golang开发流程
    WindowsTerminal优化Golang开发流程
    配置Golang环境在WindowsTerminal中的关键是设置路径和环境变量,并结合PowerShell技巧优化开发流程。1.首先通过goenv检查GOPATH和GOROOT是否正确,未设置时可在PowerShell临时设置或添加系统环境变量;2.将go/bin加入PATH以便终端直接运行程序;3.使用PowerShell别名和函数简化常用命令,如Set-Alias定义跳转目录、function定义执行脚本;4.利用WindowsTerminal多标签页提升效率,每个标签可自定义起始路径;5.安装Oh
    Golang· Go教程   |  5个月  |   golang 环境变量 PowerShell 开发效率 WindowsTerminal 476浏览 收藏
  • Golang责任链模式实现与请求处理演示
    Golang责任链模式实现与请求处理演示
    Golang中责任链模式的优势包括解耦请求发送者和接收者、简化对象、动态组合职责、易于扩展;局限性包括可能无法保证请求被处理、调试困难、性能问题、职责分配问题。1.优势:解耦请求发送者和接收者,请求者只需将请求发送到链头;简化对象,每个处理器只关注自身逻辑;动态组合职责,可灵活调整处理流程;易于扩展,新增处理器无需修改现有代码。2.局限性:无法确保请求一定被处理,可能被丢弃;链式传递使调试较复杂;链过长影响性能;职责分配不合理可能导致混乱。
    Golang· Go教程   |  5个月  |   golang 设计模式 请求处理 解耦 责任链模式 236浏览 收藏
查看更多
课程推荐
  • Golang深入理解GPM模型
    Golang深入理解GPM模型
    Golang深入理解GPM调度器模型及全场景分析,希望您看完这套视频有所收获;包括调度器的由来和分析、GMP模型简介、以及11个场景总结。
    474次学习
  • Go语言课程Gin框架实战
    Go语言课程Gin框架实战
    Gin是一个用Go(Golang)编写的HTTPweb框架。它是一个类似于 martini 但拥有更好性能的API框架,由于 httprouter,速度提高了近40倍。如果你需要极好的性能,使用Gin吧。
    339次学习
  • Golang云原生架构师课程
    Golang云原生架构师课程
    Go是一门并发支持、垃圾回收的编译型系统编程语言;本课程转载自哔哩哔哩:https://www.bilibili.com/video/BV1Mh411M7A
    205次学习
  • Go编程基础视频教程
    Go编程基础视频教程
    Go是一门并发支持、垃圾回收的编译型系统编程语言,旨在创造一门具有在静态编译语言的高性能和动态语言的高效开发之间拥有良好平衡点的一门编程语言。我们收集了这套《Go编程基础视频教程》,希望能够帮助大家更好的学习go语言。
    168次学习
  • Golang进阶实战编程
    Golang进阶实战编程
    本课程是在《Go语言基础视频》基础之上录制的,是Go语言基础的后半部分。包括包的管理,IO操作,Go语言最大的亮点:高并发,goroutine,channel,反射等。本视频主要为了帮助Go语言的初学者,从零到一的快速入门。学完本套课程,可以学会如果通过包管理Go项目,并发模型,以及并发实现,channel通道如何传递数据,反射等等。
    129次学习
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码