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

Preface

Functional programming is a style of constructing the elements and structure of a computer program by composing pure functions, avoiding shared state, mutable data, and side-effects, like we usually see in mathematics. The variable in the code function represents the value of the function parameter, and it is similar to the mathematical function. The idea is that a programmer defines the functions that contain the expression, definition, and the parameters that can be expressed by a variable to solve problems.
Functional programming is declarative rather than imperative, which means programming is done with expressions or declarations instead of statements. The application state of functional programming flows through pure functions, so it avoids the side effect. In contrast to imperative programming, the application state is usually shared and collocated with methods in objects. In imperative programming, the expressions are evaluated, and the resulting value is assigned to variables. For instance, when we group a series of expressions into a function, the resulting value depends upon the state of variables at that point in time. Because of the continuous changes in state, the order of evaluation matters. In functional programming, destructive assignment is forbidden, and each time an assignment happens, a new variable is induced. Best of all, functional code tends to be more concise and predictable, and easier to test than imperative or object-oriented code.
Although there are some specifically designed languages for functional programming, such as Haskell and Scala, we can also use C++ to accomplish designing functional programming, as we will discuss throughout this book.

主站蜘蛛池模板: 虞城县| 广灵县| 彩票| 大荔县| 哈尔滨市| 昌黎县| 萍乡市| 萍乡市| 江西省| 罗源县| 松滋市| 昆明市| 观塘区| 什邡市| 尼木县| 天水市| 涿鹿县| 南宫市| 榆中县| 怀化市| 驻马店市| 嘉兴市| 香河县| 高唐县| 马边| 秭归县| 盐源县| 包头市| 邢台市| 临海市| 聊城市| 上思县| 容城县| 邹城市| 基隆市| 探索| 玉屏| 特克斯县| 启东市| 闸北区| 哈尔滨市|