Go教程技术文章
-
当进行和 Go语言有关讨论的时候,经常听到人们抛出 CSP 这个缩写。在某些环境下 CSP 经常被赞美成 Go语言成功的原因以及并发编程的“万能钥匙”。它让不知道 CSP 的人开始认为计算机科470 收藏 -
本文实例讲述了Golang算法问题之整数拆分实现方法。分享给大家供大家参考,具体如下: 一个整数总可以拆分为2的幂的和,例如: 7=1+2+4 7=1+2+2+2 7=1+1+1+4 7=1+1+1+2+2 7=1+1+1+1+1+2 7=1+1+1+1+1+1+1 总共有6470 收藏 -
区块链开发用什么语言?通过本文你将使用Go语言开发自己的区块链(或者说用go语言搭建区块链)、理解哈希函数是如何保持区块链的完整性、掌握如何用Go语言编程创造并添加新的块、实现多个470 收藏 -
1. 前言 Golang context是Golang应用开发常用的并发控制技术,它与WaitGroup最大的不同点是context对于派生goroutine有更强的控制力,它可以控制多级的goroutine。 context翻译成中文是"上下文",即它可以控470 收藏 -
简介 上一篇文章《Go 每日一库之 securecookie》中,我们介绍了 cookie。同时提到 cookie 有两个缺点,一是数据不宜过大,二是安全问题。session 是服务器端的存储方案,可以存储大量的数据,而且470 收藏 -
不用map而用布隆过滤器是因为内存更省:上亿字符串查重时,map需几百MB,布隆过滤器仅几MB,代价是允许极小误判但绝不漏判,适合前置过滤如消息去重、URL去重等。469 收藏 -
跨服WebSocket单发与群发需依赖RedisPub/Sub实现消息中继,因gorilla/websocket仅支持本地连接操作,各节点须独立维护clientsmap并订阅统一频道,通过user_id定位目标实例后定向推送或按房间分组广播。469 收藏 -
延迟任务桶需在±50ms误差内将内存压至100MB以内,采用分层时间轮(三级:10ms/256槽、256ms/256槽、65.5s/256槽)、原子状态机防重复执行、sync.Map去重、LRU驱逐与堆管理限流,杜绝逃逸与内存泄漏。469 收藏 -
Go语言中基准测试通过testing.B可精准测函数性能,需以Benchmark开头、用b.N循环、防编译优化,运行gotest-bench=.查看ns/op等指标,配合-benchmem分析内存分配。469 收藏 -
不能直接用time.Now().UnixNano()生成分布式ID,因其纳秒级时间在高并发下仍会重复,且无机器/进程标识导致跨节点不唯一;加锁串行化则引发性能瓶颈。469 收藏 -
Go中需手写归并排序,因标准库未提供;应采用迭代式bottom-up实现,复用单个辅助切片,避免递归爆栈和频繁内存分配。469 收藏 -
不能安全跨包访问未导出变量或函数——go:linkname绕过可见性检查,但未导出符号不进导出表,易链接失败或运行时panic;仅支持标准包文档化符号或显式导出的小写符号。469 收藏 -
Go的http.ServeMux默认不防CSRF,需手动实现Token校验:服务端生成、绑定session、双向验证;Token要一次性或短时效、禁放URL、存session.Values、用crypt/rand安全生成、长度≥32字节、前端模板显式传入并正确渲染。469 收藏 -
Go标准库不内置Session支持,因设计哲学强调“小而明确”,需开发者自行实现存储与生命周期管理;Cookie须设HttpOnly、Secure、MaxAge,并用crypto/rand生成ID、登录后轮换ID防固定攻击,Redis是推荐存储方案。469 收藏 -
PVCPending核心原因是storageClassName不匹配或未显式声明;PV手动创建时若spec.storageClassName为空,则PVC必须显式写storageClassName:""才能绑定。469 收藏