函数式编程并非Go语言所特有,Go语言对函数式编程主要是体现在闭包上面。
函数式编程 vs 函数指针:
函数是一等公民:参数,变量,返回值都可以是函数(c++里只有函数指针,Java里函数只是一个名字);高阶函数:函数的参数可以是一个函数;函数–>闭包。
//闭包
func adder() func(int) int {
sum := 0
return func(v int) int {
sum += v
return sum
}
}
函数闭包:
“正统”函数式编程
1)不可变性:不能有状态,只有常量和函数; 2)函数只能有一个参数 但是学习的这篇视频不作这个严格规定。
//实现正统函数式编程不能有状态 应该放在一个新的函数里面
type iAdder func(int) (int, iAdder)
func adder2(base int) iAdder {
return func(v int) (int, iAdder) {
return base + v, adder2(base + v)
}
}
函数接口
type intGen func() int
func (g intGen) Read(
p []byte) (n int, err error) {
next := g() //取下一个元素
if next > 1000 {//达到1000以上结束
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 Fibonacci() func() int {
a, b := 0, 1
return func() int {
a, b = b, a+b
return a
}
}
func main() {
var f intGen = Fibonacci()
printFileContents(f)
}
其他语言的闭包
# Python中的闭包:python原生支持闭包、使用_closure_来查看闭包内容
def adder():
sum = 0
def f(value):
nonlocal sum
sum += value
return sum
return f
// C++中的闭包:过去stl或者boost带有类似库;C++11及以后:支持闭包 以下是C++14下编译通过的
auto adder(){
auto sum = 0;
return [-] (int value) mutable {
sum += value;
return sum;
}
}
// Java中的闭包:1.8以后:使用Function接口和Lambda表达式来创建函数对象 函数本身不能作为参数和返回值的
Function<Integer,Integer> adder() {
final Holder<Integer> sum = new Holder<>(0);
return (Integer value) -> {
sum.value += value;
return sum.value;
}
}