加入收藏 | 设为首页 | 会员中心 | 我要投稿 西安站长网 (https://www.029zz.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 移动 > 正文

手把手介绍函数式编程:从命令式重构到函数式

发布时间:2019-09-09 23:42:14 所属栏目:移动 来源:佚名
导读:副标题#e# 本文是一篇手把手的函数式编程入门介绍,借助代码示例讲解细腻。但又不乏洞见,第一节中列举和点评了函数式种种让眼花缭乱的特质,给出了『理解函数式特质的指南针:函数式代码的核心特质就一条,无副作用』,相信这个指南针对于有积极学过挖过函

在第一次迭代时, a 是什么值?并没有前一个的迭代结果可以传递。 reduce() 使用集合中的第一个元素作为第一次迭代中的 a 值,从集合的第二个元素开始迭代。也就是说,第一个 x 是集合的第二个元素。

下面的代码计算单词 'Sam' 在字符串列表中出现的次数:

  1. sentences = ['Mary read a story to Sam and Isla.', 
  2.              'Isla cuddled Sam.', 
  3.              'Sam chortled.'] 
  4.  
  5. sam_count = 0 
  6. for sentence in sentences: 
  7.     sam_count += sentence.count('Sam') 
  8.  
  9. print sam_count 
  10. # => 3 

这与下面使用 reduce 的代码相同:

  1. sentences = ['Mary read a story to Sam and Isla.', 
  2.              'Isla cuddled Sam.', 
  3.              'Sam chortled.'] 
  4.  
  5. sam_count = reduce(lambda a, x: a + x.count('Sam'), 
  6.                    sentences, 
  7.                    0) 

(编辑:西安站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读