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

Functional programming

Functional programming is a sub-paradigm of declarative programming. As opposed to imperative programming, functional programming does not change the internal state of the program.

In imperative programming, the functions can be regarded more as sequences of instructions, routines, or procedures. They not only depend on the state stored in the memory but can also change that state. This way, invoking an imperative function with the same arguments can produce different results depending on the current program's state, and at the same time, the executed function can change the program's variables.

In functional programming terminology, functions are similar to mathematical functions, and the output of a function depends only on its arguments, regardless of the program's state, which, at the same time, remains unaffected by the execution of the function.

Paradoxically, while imperative programming has existed since computers were first created, the basic concepts of functional programming dates back before that. Most functional languages are based on lambda calculus, a formal system of mathematical logic created in the 1930s by mathematician Alonzo Church.

One of the reasons why functional languages become so popular in those days is the fact that they can easily run in parallel environments. This should not be confused with multithreading. The main feature that allows functional languages to run in parallel is the basic principle on which they reside: the functions rely only on the input arguments and not on the program's state. That is, they can be run anywhere, and the results of the multiple parallel executions are then joined and used further.

主站蜘蛛池模板: 石狮市| 长白| 扶余县| 嘉荫县| 天祝| 舟山市| 陆丰市| 米林县| 百色市| 靖边县| 崇仁县| 龙山县| 吉隆县| 玛纳斯县| 文成县| 伊川县| 文登市| 增城市| 洞口县| 岳池县| 延边| 和顺县| 鞍山市| 金山区| 桂林市| 定日县| 旌德县| 夏津县| 旌德县| 宁德市| 汤阴县| 张北县| 华阴市| 全椒县| 依安县| 托克托县| 西城区| 霍山县| 白玉县| 叙永县| 昌黎县|