Go語言中的函數(shù)式編程實(shí)踐
更新時間:2018年05月29日 09:52:46 作者:Oo若離oO
這篇文章主要介紹了Go語言中的函數(shù)式編程實(shí)踐,主要講解Go語言中的函數(shù)式編程概念和使用。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
本文主要講解Go語言中的函數(shù)式編程概念和使用,分享給大家,具體如下:
主要知識點(diǎn):
- Go語言對函數(shù)式編程的支持主要體現(xiàn)在閉包上面
- 閉包就是能夠讀取其他函數(shù)內(nèi)部變量的函數(shù)。只有函數(shù)內(nèi)部的子函數(shù)才能讀取局部變量,所以閉包可以理解成“定義在一個函數(shù)內(nèi)部的函數(shù)“。在本質(zhì)上,閉包是將函數(shù)內(nèi)部和函數(shù)外部連接起來的橋梁。
- 學(xué)習(xí)閉包的基本使用
- 標(biāo)準(zhǔn)的閉包具有不可變性:不能有狀態(tài),只能有常量和函數(shù),而且函數(shù)只能有一個參數(shù),但是一般可以不用嚴(yán)格遵守
- 使用閉包 實(shí)現(xiàn) 斐波那契數(shù)列
- 學(xué)習(xí)理解函數(shù)實(shí)現(xiàn)接口
- 使用函數(shù)遍歷二叉樹
具體代碼示例如下:
package main import ( "fmt" "io" "strings" "bufio" ) //普通閉包 func adder() func(int) int { sum := 0 return func(v int) int { sum += v return sum } } //無狀態(tài) 無變量的閉包 type iAdder func(int) (int, iAdder) func adder2(base int) iAdder { return func(v int) (int, iAdder) { return base + v, adder2(base + v) } } //使用閉包實(shí)現(xiàn) 斐波那契數(shù)列 func Fibonacci() func() int { a, b := 0, 1 return func() int { a, b = b, a+b return a } } //為函數(shù) 實(shí)現(xiàn) 接口,將上面的方法 當(dāng)作一個文件進(jìn)行讀取 type intGen func() int //為所有上面這種類型的函數(shù) 實(shí)現(xiàn)接口 func (g intGen) Read( p []byte) (n int, err error) { next := g() if next > 10000 { return 0, io.EOF } s := fmt.Sprintf("%d\n", next) // TODO: incorrect if p is too small! return strings.NewReader(s).Read(p) } //通過 Reader讀取文件 func printFileContents(reader io.Reader) { scanner := bufio.NewScanner(reader) for scanner.Scan() { fmt.Println(scanner.Text()) } } func main() { //普通閉包調(diào)用 a := adder() for i := 0; i < 10; i++ { var s int =a(i) fmt.Printf("0 +...+ %d = %d\n",i, s) } //狀態(tài) 無變量的閉包 調(diào)用 b := adder2(0) for i := 0; i < 10; i++ { var s int s, b = b(i) fmt.Printf("0 +...+ %d = %d\n",i, s) } //調(diào)用 斐波那契數(shù)列 生成 fib:=Fibonacci() fmt.Println(fib(),fib(),fib(),fib(),fib(),fib(),fib(),fib()) var f intGen = Fibonacci() printFileContents(f) }
以下代碼演示函數(shù)遍歷二叉樹:
package main import "fmt" type Node struct { Value int Left, Right *Node } func (node Node) Print() { fmt.Print(node.Value, " ") } func (node *Node) SetValue(value int) { if node == nil { fmt.Println("Setting Value to nil " + "node. Ignored.") return } node.Value = value } func CreateNode(value int) *Node { return &Node{Value: value} } //為 TraverseFunc 方法提供 實(shí)現(xiàn) func (node *Node) Traverse() { node.TraverseFunc(func(n *Node) { n.Print() }) fmt.Println() } //為 Node 結(jié)構(gòu)增加一個方法 TraverseFunc , //此方法 傳入一個方法參數(shù),在遍歷是執(zhí)行 func (node *Node) TraverseFunc(f func(*Node)) { if node == nil { return } node.Left.TraverseFunc(f) f(node) node.Right.TraverseFunc(f) } func main() { var root Node root = Node{Value: 3} root.Left = &Node{} root.Right = &Node{5, nil, nil} root.Right.Left = new(Node) root.Left.Right = CreateNode(2) root.Right.Left.SetValue(4) root.Traverse() // 進(jìn)行了 打印封裝 //以下通過匿名函數(shù),實(shí)現(xiàn)了 自定義實(shí)現(xiàn) nodeCount := 0 root.TraverseFunc(func(node *Node) { nodeCount++ }) fmt.Println("Node count:", nodeCount) //Node count: 5 }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:
相關(guān)文章
淺析go中的map數(shù)據(jù)結(jié)構(gòu)字典
golang中的map是一種數(shù)據(jù)類型,將鍵與值綁定到一起,底層是用哈希表實(shí)現(xiàn)的,可以快速的通過鍵找到對應(yīng)的值。這篇文章主要介紹了go中的數(shù)據(jù)結(jié)構(gòu)字典-map,需要的朋友可以參考下2019-11-11詳解如何使用unsafe標(biāo)準(zhǔn)庫突破Golang中的類型限制
在使用c語言編程時,常常因?yàn)轭愋偷膯栴}大傷腦筋,而,golang提供了一些方式用于喜歡hack的用戶,下面我們就來講講如何使用unsafe標(biāo)準(zhǔn)庫突破Golang中的類型限制吧2024-03-03golang通用的grpc?http基礎(chǔ)開發(fā)框架使用快速入門
這篇文章主要為大家介紹了golang通用的grpc?http基礎(chǔ)開發(fā)框架使用快速入門詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09Go?并發(fā)編程協(xié)程及調(diào)度機(jī)制詳情
這篇文章主要介紹了Go并發(fā)編程協(xié)程及調(diào)度機(jī)制詳情,協(xié)程是Go語言最大的特色之一,goroutine的實(shí)現(xiàn)其實(shí)是通過協(xié)程,更多相關(guān)內(nèi)容需要的朋友可以參考一下2022-09-09