golang
已收录文章:499篇
-
使用Delve调试Go指针时,先用print命令查看指针地址和解引用值,如pp和p*p;通过exa命令检查内存原始数据,如exa-g10xc0000100a0;用pp==nil判断空指针;对结构体指针可直接访问字段,如pu.Name。475 收藏
-
Go中map传参表现如引用,因其本质是指向hmap的指针包装体,传参时值拷贝该指针,故函数内外操作同一底层数组,实现共享访问。472 收藏
-
算法选择是提升Golang程序性能的根本,如用O(logN)二分查找替代O(N)线性查找,或用O(NlogN)排序替代O(N²)算法,可实现数量级的效率提升。472 收藏
-
合理使用指针可减少内存分配并提升性能。1.大结构体应通过指针传递以避免值拷贝;2.构造函数返回指针可减少栈分配与复制;3.切片或map中存储指针可节省内存并共享数据;4.小对象值传递更高效,避免过度使用指针增加GC负担;5.结合逃逸分析和pprof工具,针对热点路径优化。471 收藏
-
实现一个Golang简易日志管理工具,支持DEBUG、INFO、WARN、ERROR四级日志,通过SetLevel控制输出级别,结合time和runtime包实现带时间、文件名和行号的格式化输出,支持控制台与文件双目标写入,利用os.OpenFile追加模式和bufio异步写入提升性能,内置文件大小超限切分机制,并通过defer或信号监听确保文件句柄安全关闭,整体封装为简洁API的Log结构体,代码精简可控,便于嵌入中小型项目并支持后续扩展。470 收藏
-
使用Golang模拟CPU负载过高可通过启动多个执行计算密集型任务的goroutine实现,每个goroutine占用一个CPU核心,从而提升整体CPU使用率;具体方法是在main函数中根据CPU核心数启动相应数量的goroutine,每个goroutine持续调用如computeSomething等耗时计算函数,运行指定时间后通过context或信号机制优雅停止;模拟网络延迟则借助os/exec包调用Linux的tc命令,在指定网络接口上添加延迟规则,需使用sudo权限执行“tcqdiscadd”命令设469 收藏