大家还是直接看代码吧~
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
|
package main
import (
"fmt"
)
func init() {
fmt.Print("init")
}
func main() {
test1("123")
test1(1)
test2("123",1, "324", 12)
}
// 实现传单个任何类型的参数
func test1(v interface{}) {
fmt.Println(v) // 打印 “123” 1
}
// 实现传任意多个任意类型的参数
func test2(v ...interface{}) {
for _, m := range v {
fmt.Println(m) // 依次打印 123 1 324 12
}
}
|
补充:golang 函数作为参数传递(回调)的例子
和其他很多语言一样,golang中函数也可以作为其它函数的参数进行传递,然后在其它函数内调用执行,一般称之为回调。
语法:
以函数签名作为主调函数的形参的类型,即传递一个指向函数的指针
1
2
3
4
5
6
7
8
9
|
func main() {
sayhello("john", addperfix)
}
func addperfix(perfix, name string) {
fmt.Println(perfix, "!", name)
}
func sayhello(name string, f func(string, string)) {
f("hello", name)
}
|
补充:golang函数形参接收任意类型的切片
在某些情况下一个函数可能既需要接收[]string类型的切片也可能接收[]int类型的切片,或接收自定义类型的切片。
我首先想到的办法是创建一个[]interface{}类型的切片
如下所示:
1
2
3
4
5
6
7
8
9
|
func demo(s []interface{}) {
for _, ele := range s {
fmt.Println(ele)
}
}
func Test(t *testing.T) {
s := []int{1, 2, 3}
demo(s)
}
|
但不幸的是,我得到了
cannot use s (type []int) as type []interface {} in argument to demo 这个错误。
原因是interface{}类型的变量可以指向任意类型的值,但[]interface{}类型的指针只能指向[]interface{}类型的值而不能指向任意类型的切片。
为了实现上述功能,我想到的办法是利用反射中的Slice:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
func demo(s interface{}) {
sv := reflect.ValueOf(s)
svs := sv.Slice(0, sv.Len())
for i := 0; i < svs.Len(); i++ {
e := svs.Index(i).Interface()
switch e.(type) {
case string:
fmt.Println("string", e)
case int:
fmt.Println("int", e)
}
}
}
func Test(t *testing.T) {
s1 := []int{1, 2, 3}
demo(s1)
s2 := []string{"a", "b", "c"}
demo(s2)
}
|
以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。如有错误或未考虑完全的地方,望不吝赐教。
原文链接:https://blog.csdn.net/panguangyuu/article/details/89676649