慕沐林林
某些语言(C、Python、...)接受可变参数。基本上,您允许函数的客户端传递多个参数,而无需指定多少。由于该函数仍需要以一种或另一种方式处理这些参数,因此它们通常被转换为某种集合。例如,在 Python 中:def foo(x, *args): # * is used for variadic arguments return len(args)>>> foo(1) # Passed the required argument, but no varargs0 >>> foo(1, 2, 3) # Passed the required, plus two variadic arguments2>>> foo(1, 2, 3, 4, 5, 6) # required + 5 args, etc...5现在这种方法的一个明显问题是,就类型而言,许多参数是一个相当模糊的概念。C 使用指针,Python 一开始并不真正关心类型,Go 决定将其限制在特定情况下:传递给定类型的切片。这很好,因为它让类型系统做它的事情,同时仍然非常灵活(特别是,所讨论的类型可以是一个接口,所以只要函数知道如何处理,你就可以传递不同的“实际类型”这些。典型的例子是命令函数,它执行一个程序,传递一些参数:func Command(name string, arg ...string) *Cmd这在这里很有意义,但请记住,可变参数只是传递 slices 的一种便捷方式。您可以拥有完全相同的 API:func Command(name string, args []string) *Cmd第一个的唯一优点是它可以让你不传递任何参数,一个参数,几个......而不必自己构建切片。那你的问题呢?有时,您确实有一个切片,但需要调用一个可变参数函数。但如果你天真地这样做:my_args_slice := []string{"foo", "bar"}cmd := Command("myprogram", my_args_slice)编译器会抱怨它需要字符串,但却得到了一个切片!您要告诉它的是,它不必“在后面构建切片”,因为您已经有了切片。您可以使用以下省略号来做到这一点:my_args_slice := []string{"foo", "bar"}cmd := Command("myprogram", my_args_slice...) // <- Interpret that as strings该append函数尽管是内置的和特殊的,但遵循相同的规则。您可以将零个、一个或多个元素附加到切片。如果您想连接切片(即您已经有一个“参数切片”),您同样可以使用省略号使其直接使用它。