Go语言支持可变参数函数,通过...T定义且必须位于参数列表末尾,如func sum(numbers ...int) int;可变参数实际类型为[]T,可使用len获取数量、通过索引访问,支持零个或多个值调用,切片传参需用slice...展开;函数可同时含固定参数与可变参数,如greet(prefix string, names ...string),调用时先传固定参数再传可变参数,使函数更灵活。

Go语言支持可变参数函数,允许函数接收不定数量的参数。这种特性在处理不确定参数个数的场景时非常实用,比如日志记录、字符串格式化等。
可变参数的定义方式
在函数参数列表中,使用 ...T 表示该参数是可变参数,T 是类型。可变参数必须放在参数列表的最后。
例如:func sum(numbers ...int) int {
total := 0
for _, num := range numbers {
total += num
}
return total
}
这个函数可以接收任意数量的 int 类型参数,包括零个。
调用可变参数函数
调用时可以传入零个或多个对应类型的值。
立即学习“go语言免费学习笔记(深入)”;
sum() // 0
sum(1) // 1
sum(1, 2, 3) // 6
也可以将切片传递给可变参数,但需要展开:在切片变量后加 ...。
nums := []int{1, 2, 3, 4}
sum(nums...) // 正确:将切片元素展开传入
可变参数的底层机制
可变参数的类型实际上是切片([]T)。在函数内部,
numbers ...int等价于
numbers []int,可以像操作切片一样遍历、取长度等。
这意味着你可以:
- 使用
len(numbers)
获取参数个数 - 通过索引访问单个参数:
numbers[0]
- 传递子切片给其他可变参数函数
混合固定参数与可变参数
函数可以同时有固定参数和可变参数,但可变参数必须在最后。
func greet(prefix string, names ...string) {
for _, name := range names {
fmt.Println(prefix, name)
}
}
调用示例:
greet("Hello", "Alice", "Bob")
基本上就这些。可变参数让函数更灵活,使用时注意类型匹配和切片展开即可。










