go 语言中没有固定长度限制的“动态数组”,但可通过 `append()` 函数实现类似 java `arraylist` 的自动扩容行为,无需预先指定容量,时间复杂度为均摊 o(1)。
在 Go 中,切片(slice)本身不是动态容器,但它配合 append() 函数可高效模拟动态数组语义。与 Java 的 ArrayList.add() 类似,append() 会在底层数组容量不足时自动分配更大内存,并将原数据复制过去——这一过程对开发者完全透明。
关键在于:初始化一个长度为 0、容量可变的切片,而非预设大容量(如 make([]string, 100))。这样既避免内存浪费,又消除手动索引管理(如 i++)的错误风险。
以下是优化后的目录文件列表示例:
package main
import (
"fmt"
"io/ioutil" // 注意:Go 1.16+ 推荐使用 os.ReadDir 替代 ioutil
)
func listFile() []string {
var list []string // 等价于 make([]string, 0),更简洁的零值声明
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.P
rintln(listFile()) // 输出类似:[1.txt 2.txt tmp]
}✅ 最佳实践提示:
总结:Go 切片虽无内置 add() 方法,但 append() + 零长度切片的组合,正是官方推荐的、兼具安全性、性能与简洁性的“动态集合”实现方式。