golang
已收录文章:14010篇
-
ioutil.ReadFile适用于小文件读取,但大文件需用bufio.Scanner逐行处理以节省内存;Go1.16后推荐使用os.ReadFile替代ioutil.ReadFile,临时文件操作建议迁移到os.MkdirTemp和os.CreateTemp。481 收藏
-
掌握bytes包核心函数可提升Go语言中字节切片操作效率。1.使用Contains、Index、Equal进行查找与比较;2.利用Split和Join实现分割与连接;3.通过ReplaceAll、Trim、TrimSpace完成替换与修剪;4.借助Buffer高效拼接数据,避免内存频繁分配。481 收藏
-
责任链模式通过将请求沿处理器链传递实现解耦,Go中利用接口和结构体组合构建链条,每个处理器决定处理或转发请求,适用于中间件、审批流等场景,具有高扩展性和低耦合优势,需注意设置终止条件和链长度以避免递归或性能问题。481 收藏
-
Go 语言中 goroutine + channel 通过通信的方式来共享内存,从而实现并发编程。 但同时 Go 也提供了传统通过共享变量,也就是共享内存的方式来实现并发。这篇文章会介绍 Go提供的相关机制。 1、480 收藏
-
Golang的string类型底层数据结构简单,本质也是一个结构体实例,且是const不可变。 string的底层数据结构 通过下面一个例子来看: package main import ( "fmt" "unsafe" ) // from: string.go 在GoLand IDE中双击s480 收藏
-
1.问题现象描述 使用 json.Unmarshal(),反序列化时,出现了科学计数法,参考代码如下: jsonStr := `{"number":1234567}` result := make(map[string]interface{}) err := json.Unmarshal([]byte(jsonStr), &result) if err != nil {480 收藏