go 语言中没有固定长度限制的“动态数组”,但可通过 append() 函数实现类似 java arraylist 的自动扩容行为,无需预估容量,元素追加具有 o(1) 均摊时间复杂度。
在 Go 中,slice 本身不是动态容器类型,但它配合 append() 函数可高效模拟动态数组行为。与 Java 的 ArrayList.add() 类似,你无需预先指定容量或手动管理底层数组扩容——Go 运行时会自动处理内存分配与复制。
关键在于:初始化一个长度为 0、容量可变的 slice,并持续使用 append() 追加元素。例如,遍历目录获取所有文件名:
package main
import (
"fmt"
"io/ioutil" // 注意:Go 1.16+ 推荐使用 os.ReadDir 替代 ioutil.ReadDir
)
func listFile() []string {
var list []string // 等价于 make([]string, 0),零长度 slice,初始容量由运行时决定
files, err := ioutil.ReadDir("content/")
if err != nil {
panic(err) // 实际项目中应妥善处理错误,而非 panic
}
for _, f := range files {
list = append(list, f.Name()) // 自动扩容:容量不足时分配新底层数组并复制
}
return list
}
func main() {
fmt.Println(listFile()) // 输出类似:[1.txt 2.txt tmp]
}✅ 优势说明:
⚠️ 注意事项:
总之,Go 的 slice + append() 组合是标准、高效、惯用的动态集合方案——它不是语法糖,而是经过深度优化的底层机制,完全满足
“无需关心长度”的开发需求。