官术网_书友最值得收藏!

Functions, Iterators, and Generators

The core of functional programming is the use of pure functions to map values from the input domain to the output range. A pure function has no side effects, a relatively easy threshold for us to achieve in Python.

Avoiding side effects can lead to reducing any dependence on variable assignment to maintain the state of our computations. We can't purge the assignment statement from the Python language, but we can reduce our dependence on stateful objects. This means choosing among the available Python built-in functions and data structures to select those that don't require stateful operations.

This chapter will present several Python features from a functional viewpoint, as follows:

  • Pure functions, free of side effects
  • Functions as objects that can be passed as arguments or returned as results
  • The use of Python strings using object-oriented suffix notation and prefix notation
  • Using tuples and named tuples as a way to create stateless objects
  • Using iterable collections as our primary design tool for functional programming

We'll look at generators and generator expressions, since these are ways to work with collections of objects. As we noted in Chapter 2, Introducing Essential Functional Concepts, there are some boundary issues when trying to replace all generator expressions with recursions. Python imposes a recursion limit, and doesn't automatically handle Tail Call Optimization (TCO): we must optimize recursions manually using a generator expression.

We'll write generator expressions that will perform the following tasks:

  • Conversions
  • Restructuring
  • Complex calculations

We'll take a quick survey of many of the built-in Python collections, and how we can work with collections while pursuing a functional paradigm. This may change our approach to working with lists, dicts, and sets. Writing functional Python encourages us to focus on tuples and immutable collections. In the next chapter, we'll emphasize more functional ways to work with specific kinds of collections.

主站蜘蛛池模板: 綦江县| 磐石市| 湛江市| 左权县| 二连浩特市| 南宁市| 资兴市| 大悟县| 蚌埠市| 明星| 丹棱县| 东兴市| 嫩江县| 安多县| 潮安县| 大兴区| 诸暨市| 香河县| 大埔区| 宜阳县| 阿拉尔市| 昭平县| 高雄市| 荆州市| 巴青县| 宁强县| 柏乡县| 新巴尔虎左旗| 柘城县| 吐鲁番市| 抚顺市| 南昌县| 潜江市| 丹寨县| 游戏| 迁安市| 永年县| 鄂伦春自治旗| 厦门市| 克什克腾旗| 凉城县|