一概念(函數(shù)式編程)
函數(shù)式編程是一種編程范式,我們常見(jiàn)的編程范式有命令式編程(Imperativeprogramming),函數(shù)式編程,常見(jiàn)的面向?qū)ο缶幊淌且彩且环N命令式編程。
命令式編程是面向計(jì)算機(jī)硬件的抽象,有變量(對(duì)應(yīng)著存儲(chǔ)單元),賦值語(yǔ)句(獲取,存儲(chǔ)指令),表達(dá)式(內(nèi)存引用和算術(shù)運(yùn)算)和控制語(yǔ)句(跳轉(zhuǎn)指令),一句話,命令式程序就是一個(gè)馮諾依曼機(jī)的指令序列。
而函數(shù)式編程是面向數(shù)學(xué)的抽象,將計(jì)算描述為一種表達(dá)式求值,一句話,函數(shù)式程序就是一個(gè)表達(dá)式。
函數(shù)式編程的本質(zhì)
函數(shù)式編程中的函數(shù)這個(gè)術(shù)語(yǔ)不是指計(jì)算機(jī)中的函數(shù),而是指數(shù)學(xué)中的函數(shù),即自變量的映射。也就是說(shuō)一個(gè)函數(shù)的值僅決定于函數(shù)參數(shù)的值,不依賴其他狀態(tài)。比如y=x*x函數(shù)計(jì)算x的平方根,只要x的平方,不論什么時(shí)候調(diào)用,調(diào)用幾次,值都是不變的。
純函數(shù)式編程語(yǔ)言中的變量也不是命令式編程語(yǔ)言中的變量,即存儲(chǔ)狀態(tài)的單元,而是代數(shù)中的變量,即一個(gè)值的名稱。變量的值是不可變的(immutable),也就是說(shuō)不允許像命令式編程語(yǔ)言中那樣多次給一個(gè)變量賦值。比如說(shuō)在命令式編程語(yǔ)言我們寫“x=x+1”,這依賴可變狀態(tài)的事實(shí),拿給程序員看說(shuō)是對(duì)的,但拿給數(shù)學(xué)家看,卻被認(rèn)為這個(gè)等式為假。
函數(shù)式語(yǔ)言的如條件語(yǔ)句,循環(huán)語(yǔ)句也不是命令式編程語(yǔ)言中的控制語(yǔ)句,而是函數(shù)的語(yǔ)法糖,比如在Scala語(yǔ)言中,ifelse不是語(yǔ)句而是三元運(yùn)算符,是有返回值的。
嚴(yán)格意義上的函數(shù)式編程意味著不使用可變的變量,賦值,循環(huán)和其他命令式控制結(jié)構(gòu)進(jìn)行編程。
函數(shù)式編程關(guān)心數(shù)據(jù)的映射,命令式編程關(guān)心解決問(wèn)題的步驟,這也是為什么“函數(shù)式編程”叫做“函數(shù)式編程”。
以上內(nèi)容為大家介紹了python函數(shù)式編程到底是個(gè)什么,希望對(duì)大家有所幫助,如果想要了解更多Python相關(guān)知識(shí),請(qǐng)關(guān)注IT培訓(xùn)機(jī)構(gòu):千鋒教育。