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