Go语言笔记2
正文
//函數(shù)式編程
//函數(shù)與閉包
/概念一
函數(shù)是 一等公民,
也就是說
參數(shù),變量,返回值都可以是函數(shù).
概念二
高階函數(shù)參數(shù)是函數(shù).
概念三
正統(tǒng)函數(shù)式編程.
不可變性,不能有狀態(tài),只有常量和函數(shù),
函數(shù)只能有一個(gè)參數(shù)。/
例子一
package chapter2 // 引入 import ("bufio""fmt""io""strings" ) //定義 fib函數(shù) func fibonacci() intGen{a,b:=0,1return func() int{a,b=b,a+breturn a} } // 創(chuàng)建新類型 type intGen func() intfunc (g intGen)Read(p []byte)(n int,err error){next :=g()if next>10000{return 0,io.EOF}s:=fmt.Sprintf("%d\n",next)return strings.NewReader(s).Read(p) }func printFileContents(reader io.Reader){scanner:=bufio.NewScanner(reader)for scanner.Scan(){fmt.Println(scanner.Text())} } func main(){f:=fibonacci()f()f()printFileContents(f)}例子三
package chapter2import "fmt"type Node struct{Left,Right *NodeVal int } func (node *Node)Traverse(){node.TraverseFunc(func (node *Node){node.Print()})fmt.Println(1) } func (node *Node)TraverseFunc(f func(*Node)){if node ==nil{return}node.Left.TraverseFunc(f)f(node)node.Right.TraverseFunc(f) } //更為自然,不需要修飾如何訪問自由變量 //沒有l(wèi)ambda 表達(dá)式,但是有匿名函數(shù)。總結(jié)
- 上一篇: Go 语言笔记 1
- 下一篇: mmd python error_pyt