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

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.

主站蜘蛛池模板: 盐山县| 侯马市| 调兵山市| 盐池县| 台安县| 望江县| 黄大仙区| 于田县| 蒲江县| 内江市| 永春县| 黑龙江省| 集安市| 大同县| 芒康县| 瑞安市| 彩票| 惠水县| 伊春市| 兴海县| 库伦旗| 波密县| 林甸县| 沁阳市| 石林| 公安县| 凤翔县| 淮南市| 南澳县| 阜平县| 泰兴市| 桃江县| 新竹市| 塔城市| 永定县| 宝山区| 罗山县| 贡觉县| 长寿区| 孟村| 基隆市|