偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

函數(shù)式編程是一個(gè)倒退

開發(fā) 后端
就在這美麗的新世界即將來到之際,就在我們摩拳擦掌打算大干一番之前,我想,現(xiàn)在應(yīng)該是我們暫停一下、反省一下函數(shù)式編程在我們的日常應(yīng)用開發(fā)中是否合適的好時(shí)機(jī)。

[[92711]]

除非你生活中與世隔絕的深山老林里,否則你應(yīng)該知道,在眾多的所謂頂級(jí)編程高手(alpha geeks)中,函數(shù)式編程是十分盛行的。也許你已經(jīng)使用了某種函數(shù)式編程語言。如果你是在使用很傳統(tǒng)的編程語言,例如 Java 或 C#,你應(yīng)該知道了,這些語言很快就將引入一些函數(shù)式編程特征。就在這美麗的新世界即將來到之際,就在我們摩拳擦掌打算大干一番之前,我想,現(xiàn)在應(yīng)該是我們暫停一下、反省一下函數(shù)式編程在我們的日常應(yīng)用開發(fā)中是否合適的好時(shí)機(jī)。

什么是函數(shù)式編程?簡單的回答:一切都是數(shù)學(xué)函數(shù)。函數(shù)式編程語言里也可以有對(duì)象,但通常這些對(duì)象都是恒定不變的 —— 要么是函數(shù)參數(shù),要什么是函數(shù)返回值。函數(shù)式編程語言里沒有 for/next 循環(huán),因?yàn)檫@些邏輯意味著有狀態(tài)的改變。相替代的是,這種循環(huán)邏輯在函數(shù)式編程語言里是通過遞歸、把函數(shù)當(dāng)成參數(shù)傳遞的方式實(shí)現(xiàn)的。

為什么要使用函數(shù)式編程

擁護(hù)者說函數(shù)式編程能開發(fā)出更高效的軟件,而反對(duì)者說反之亦然。我感覺雙方的觀點(diǎn)都有問題。我可以輕松的證明函數(shù)式編程能使你更難寫出針對(duì)編譯器優(yōu)化的代碼,或者相較于傳統(tǒng)語言的代碼,JIT 編譯器對(duì)于函數(shù)式代碼會(huì)編譯出更慢的程序。命令式編程語言(imperative programming languages)語法跟底層的計(jì)算機(jī)硬件指令間有著很相似的對(duì)應(yīng)關(guān)系,但函數(shù)式編程語言卻沒有這種特征。結(jié)果就是,編譯器處理函數(shù)式編程語言時(shí)更費(fèi)力。

然而,優(yōu)秀的編譯器能把函數(shù)式編程中的閉包、tail 調(diào)用、或 lambda 表達(dá)式轉(zhuǎn)換成跟傳統(tǒng)語言中 loop 循環(huán)或其它表達(dá)式等效的代碼。這需要多做一些工作。如果你在尋找一本厚達(dá) 1600 頁的關(guān)于這方面的好書,我推薦你《Optimizing Compilers for Modern Architectures: A Dependence-based Approach》和《Advanced Compiler Design and Implementation》?;蛘吣阋部梢允褂?GCC 或任何具有多階段編譯功能、能生成匯編代碼的編譯器自己去證明這一點(diǎn)。

對(duì)于為什么要使用函數(shù)式編程,這有一個(gè)更好的論據(jù),現(xiàn)代的應(yīng)用程序都會(huì)牽涉到多核計(jì)算機(jī)上的并行運(yùn)算功能,程序狀態(tài)就成了一個(gè)問題。所有的命令式語言,包括面向?qū)ο笳Z言,在涉及多線程時(shí),都會(huì)遇到共享對(duì)象的狀態(tài)修改問題。這就是死鎖、堆棧跟蹤、低級(jí)處理器緩存命中率低等問題的根源。如果對(duì)象沒有狀態(tài),這些問題就不存在了。

在很多地方使用函數(shù)式編程或函數(shù)式編程語言都是非常適合的,甚至是最好的選擇。對(duì)于純函數(shù)計(jì)算,函數(shù)式編程明顯的比命令式編程更合適。但對(duì)于商業(yè)軟件或其它普通應(yīng)用軟件,你不能不說這正好要顛倒過來。就像 Martin Fowler 著名的闡述,“傻子都能寫出計(jì)算機(jī)可讀懂的代碼。優(yōu)秀的程序員寫出的是人能讀懂的代碼。”而函數(shù)式編程寫出的代碼就是讓人一眼望去不可讀。

幾段代碼就能讓你知道我說的是什么意思。來自 Erlang 語言的代碼例子:

  1. -module (listsort).  
  2. -export ([by_length/1]).  
  3. by_length (Lists) ->  
  4. qsort (Lists, fun (A,B) -> A < B end).  
  5. qsort ([], _)-> [];  
  6. qsort ([Pivot|Rest], Smaller) ->  
  7. qsort ([X || X <- Rest, Smaller (X,Pivot)], Smaller)  
  8. ++ [Pivot] ++  
  9. qsort ([Y || Y <- Rest, not (Smaller (Y, Pivot))], Smaller). 

這個(gè)是 Haskell 語言的:

  1. -- file: ch05/Prettify.hs  
  2. pretty width x = best 0 [x]  
  3. where best col (d:ds) =  
  4. case d of  
  5. Empty -> best col ds  
  6. Char c -> c : best (col + 1) ds  
  7. Text s -> s ++ best (col + length s) ds  
  8. Line -> '\n' : best 0 ds  
  9. a `Concat` b -> best col (a:b:ds)  
  10. a `Union` b -> nicest col (best col (a:ds))  
  11. (best col (b:ds))  
  12. best _ _ = "" 
  13. nicest col a b | (width - least) `fits` a = a  
  14. | otherwise = b  
  15. where least = min width col 

人 vs 機(jī)器

一個(gè)不怎么樣的程序員一般都能從一段命令式的代碼中很快的看出其基本的功用 —— 甚至這是一種他從未見過的語言。然而雖然你也能從一段函數(shù)式代碼里分析出它的功用,但你絕對(duì)不可能簡單幾眼就能看出來。不像命令式代碼,函數(shù)式代碼并不體現(xiàn)出簡單的語言結(jié)構(gòu)。它展現(xiàn)的都是數(shù)學(xué)結(jié)構(gòu)。

我們的編程經(jīng)歷了從紙帶打孔到匯編到宏匯編到C語言(高級(jí)宏匯編)再到抽象出了很多老實(shí)機(jī)器上復(fù)制運(yùn)算的高等編程語言。每一步都使我們?cè)絹碓浇咏缎请H迷航4》里的場(chǎng)景:遇到麻煩的 Scott 對(duì)他的鼠標(biāo)說出指令(“Hello computer“)。數(shù)十年的進(jìn)步使得編程語言越來越容易被人類閱讀和理解,函數(shù)式編程的語法是在把時(shí)鐘指針往后撥。

函數(shù)式編程能解決并行運(yùn)算的狀態(tài)問題,但付出的代價(jià)是失去人類可讀性。函數(shù)式編程也許完全可以用于任何環(huán)境開發(fā),它甚至可以通過定義面向領(lǐng)域(domain-specific)的編程語言來拉近人類語言和計(jì)算機(jī)語言之間的距離。但它糟糕的語法使得它極不適合常規(guī)目的的編程開發(fā)。

不要這么著急的判斷潮流 —— 特別對(duì)于那些不想有太多風(fēng)險(xiǎn)的項(xiàng)目。

英文原文:Functional programming: A step backward

【編輯推薦】

  1. 函數(shù)式編程如何才有一席之地
  2. 函數(shù)要多小才夠好——談小函數(shù)之道
  3. 沒有完美的軟件:編程永遠(yuǎn)不容易
  4. Rob Pike:我得到的最有價(jià)值的編程建議
  5. 最有價(jià)值的編程忠告(來自貝爾實(shí)驗(yàn)室Plan 9操作系統(tǒng)的創(chuàng)始人Rob Pike)
責(zé)任編輯:張偉 來源: 外刊IT評(píng)論
相關(guān)推薦

2015-05-25 15:06:28

JavaScript函數(shù)式編程

2020-04-20 09:02:33

函數(shù)RPCCPU

2021-08-02 08:21:53

Python編程語言開發(fā)

2016-08-11 10:11:07

JavaScript函數(shù)編程

2009-06-22 13:43:01

F#函數(shù)式編程

2013-03-04 09:47:08

Python函數(shù)式編程

2013-09-09 09:41:34

2020-11-01 09:05:16

函數(shù)式編程編程數(shù)據(jù)分析

2017-09-15 16:02:15

函數(shù)代碼CPU

2012-10-22 14:17:42

函數(shù)式程序員

2021-04-14 07:33:02

Java函數(shù)式斷言

2011-08-24 09:13:40

編程

2023-12-14 15:31:43

函數(shù)式編程python編程

2022-09-22 08:19:26

WebFlux函數(shù)式編程

2016-10-31 20:46:22

函數(shù)式編程Javascript

2011-03-08 15:47:32

函數(shù)式編程

2020-09-24 10:57:12

編程函數(shù)式前端

2025-03-11 10:00:20

Golang編程函數(shù)

2017-06-08 14:25:46

Kotlin函數(shù)

2019-08-06 09:00:00

JavaScript函數(shù)式編程前端
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)