大家還是直接看代碼吧~
package main
import (
"fmt"
)
func init() {
fmt.Print("init")
}
func main() {
test1("123")
test1(1)
test2("123",1, "324", 12)
}
// 實(shí)現(xiàn)傳單個(gè)任何類型的參數(shù)
func test1(v interface{}) {
fmt.Println(v) // 打印 “123” 1
}
// 實(shí)現(xiàn)傳任意多個(gè)任意類型的參數(shù)
func test2(v ...interface{}) {
for _, m := range v {
fmt.Println(m) // 依次打印 123 1 324 12
}
}
補(bǔ)充:golang 函數(shù)作為參數(shù)傳遞(回調(diào))的例子
和其他很多語(yǔ)言一樣,golang中函數(shù)也可以作為其它函數(shù)的參數(shù)進(jìn)行傳遞,然后在其它函數(shù)內(nèi)調(diào)用執(zhí)行,一般稱之為回調(diào)。
語(yǔ)法:
以函數(shù)簽名作為主調(diào)函數(shù)的形參的類型,即傳遞一個(gè)指向函數(shù)的指針
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)
}
補(bǔ)充:golang函數(shù)形參接收任意類型的切片
在某些情況下一個(gè)函數(shù)可能既需要接收[]string類型的切片也可能接收[]int類型的切片,或接收自定義類型的切片。
我首先想到的辦法是創(chuàng)建一個(gè)[]interface{}類型的切片
如下所示:
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 這個(gè)錯(cuò)誤。
原因是interface{}類型的變量可以指向任意類型的值,但[]interface{}類型的指針只能指向[]interface{}類型的值而不能指向任意類型的切片。
為了實(shí)現(xiàn)上述功能,我想到的辦法是利用反射中的Slice:
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)
}
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
您可能感興趣的文章:- Golang中Bit數(shù)組的實(shí)現(xiàn)方式
- 解決Golang time.Parse和time.Format的時(shí)區(qū)問題
- Golang 使用Map實(shí)現(xiàn)去重與set的功能操作
- 使用Golang的channel交叉打印兩個(gè)數(shù)組的操作
- golang goroutine順序輸出方式
- golang 在windows中設(shè)置環(huán)境變量的操作
- 解決golang在import自己的包報(bào)錯(cuò)的問題
- golang 通用Contains方法分享