介面型函數:指的是用函數實現介面,這樣在調用的時候就會非常簡便,這種函數為介面型函數,這種方式適用於只有一個函數的介面。
定義一個類型,這個類型只定義了函數的參數列表,函數參數列表與介面定義的方法一致:
type HandlerFunc func(k, v interface{})
然後這個類型去實現介面,實現的函數調用自己
func (hf HandlerFunc) Do(k, v interface{}) {hf(k, v) // 介面的實現中調用本身。這樣就使得可以用函數來實現介面功能,而不是定義類型並實現介面來實現介面功能}
這樣就可以用兩種方法去實現介面功能
func Each(mp map[interface{}]interface{}, h Handler) { // 傳入一個實現了Handler介面的類型的執行個體}func EachFunc(mp map[interface{}]interface{}, handlerFunc HandlerFunc) { // 傳入了一個參數列表為介面所需實現函數的}
第二種方式可以只傳入一個函數,只要求參數列表一致,函數名字可隨便起,類型也不用新定義,用起來很方便。
完整代碼如下;
package mainimport "fmt"type Handler interface {Do (k, v interface{})}type HandlerFunc func(k, v interface{})func (hf HandlerFunc) Do(k, v interface{}) {hf(k, v)}func Each(mp map[interface{}]interface{}, h Handler) {if mp != nil && len(mp) > 0 {for k, v := range mp {h.Do(k, v)}}}func EachFunc(mp map[interface{}]interface{}, handlerFunc HandlerFunc) {if mp != nil && len(mp) > 0 {for k, v := range mp {handlerFunc(k, v)}}}func selfInfo(k, v interface{}) {fmt.Printf("my name is %s, i am %d years old", k, v)fmt.Println()}func main() {mp := map[interface{}]interface{}{"gaoziwen":26,"zhangsan":27,"lisi":28,}f := selfInfoEachFunc(mp, f)}