主頁 > 知識庫 > Go語言中的函數(shù)式編程實踐

Go語言中的函數(shù)式編程實踐

熱門標簽:鄭州亮點科技用的什么外呼系統(tǒng) 汕頭小型外呼系統(tǒng) 惠州電銷防封電話卡 建造者2地圖標注 阿里云ai電話機器人 黃岡人工智能電銷機器人哪個好 濱州自動電銷機器人排名 釘釘有地圖標注功能嗎 浙江高頻外呼系統(tǒng)多少錢一個月

本文主要講解Go語言中的函數(shù)式編程概念和使用,分享給大家,具體如下:

主要知識點:

  1. Go語言對函數(shù)式編程的支持主要體現(xiàn)在閉包上面
  2. 閉包就是能夠讀取其他函數(shù)內(nèi)部變量的函數(shù)。只有函數(shù)內(nèi)部的子函數(shù)才能讀取局部變量,所以閉包可以理解成“定義在一個函數(shù)內(nèi)部的函數(shù)“。在本質(zhì)上,閉包是將函數(shù)內(nèi)部和函數(shù)外部連接起來的橋梁。
  3. 學習閉包的基本使用
  4. 標準的閉包具有不可變性:不能有狀態(tài),只能有常量和函數(shù),而且函數(shù)只能有一個參數(shù),但是一般可以不用嚴格遵守
  5. 使用閉包 實現(xiàn) 斐波那契數(shù)列
  6. 學習理解函數(shù)實現(xiàn)接口
  7. 使用函數(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)
 }
}

//使用閉包實現(xiàn) 斐波那契數(shù)列
func Fibonacci() func() int {
 a, b := 0, 1
 return func() int {
 a, b = b, a+b
 return a
 }
}

//為函數(shù) 實現(xiàn) 接口,將上面的方法 當作一個文件進行讀取
type intGen func() int
//為所有上面這種類型的函數(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 方法提供 實現(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() // 進行了 打印封裝

 //以下通過匿名函數(shù),實現(xiàn)了 自定義實現(xiàn)
 nodeCount := 0
 root.TraverseFunc(func(node *Node) {
 nodeCount++
 })
 fmt.Println("Node count:", nodeCount) //Node count: 5
}

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • GO 函數(shù)式選項模式(Functional Options Pattern)

標簽:昭通 阿壩 東營 滄州 晉中 泰安 瀘州 駐馬店

巨人網(wǎng)絡(luò)通訊聲明:本文標題《Go語言中的函數(shù)式編程實踐》,本文關(guān)鍵詞  語言,中的,函,數(shù)式,編程,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Go語言中的函數(shù)式編程實踐》相關(guān)的同類信息!
  • 本頁收集關(guān)于Go語言中的函數(shù)式編程實踐的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章