主要的編程範式有三種:命令式編程,聲明式編程和函數式編程。 命令式編程: 命令式編程的主要思想是關註電腦執行的步驟,即一步一步告訴電腦先做什麼再做什麼。 比如:如果你想在一個數字集合 collection(變數名) 中篩選大於 5 的數字,你需要這樣告訴電腦: 第一步,創建一個存儲結果的集合變 ...
主要的編程範式有三種:命令式編程,聲明式編程和函數式編程。
命令式編程:
命令式編程的主要思想是關註電腦執行的步驟,即一步一步告訴電腦先做什麼再做什麼。
比如:如果你想在一個數字集合 collection(變數名) 中篩選大於 5 的數字,你需要這樣告訴電腦:
- 第一步,創建一個存儲結果的集合變數 results;
- 第二步,遍歷這個數字集合 collection;
- 第三步:一個一個地判斷每個數字是不是大於 5,如果是就將這個數字添加到結果集合變數 results 中。
代碼實現如下:
List<int> results = new List<int>(); foreach(var num in collection) { if (num > 5) results.Add(num); }
很明顯,這個樣子的代碼是很常見的一種,不管你用的是 C, C++ 還是 C#, Java, Javascript, BASIC, Python, Ruby 等等,你都可以以這個方式寫。
聲明式編程:
聲明式編程是以數據結構的形式來表達程式執行的邏輯。它的主要思想是告訴電腦應該做什麼,但不指定具體要怎麼做。
SQL 語句就是最明顯的一種聲明式編程的例子,例如:
SELECT * FROM collection WHERE num > 5
除了 SQL,網頁編程中用到的 HTML 和 CSS 也都屬於聲明式編程。
通過觀察聲明式編程的代碼我們可以發現它有一個特點是它不需要創建變數用來存儲數據。
另一個特點是它不包含迴圈控制的代碼如 for, while。
函數式編程:
函數式編程和聲明式編程是有所關聯的,因為他們思想是一致的:即只關註做什麼而不是怎麼做。但函數式編程不僅僅局限於聲明式編程。
函數式編程最重要的特點是“函數第一位”,即函數可以出現在任何地方,比如你可以把函數作為參數傳遞給另一個函數,不僅如此你還可以將函數作為返回值。大部分常見的編程語言一半都已經提供了對這種編程方式的支持,比如 JavaScript,再有 C# 中的 LINQ 和 Java 中的 Lambda 和閉包的概念。
Java 8 最大的一個對函數式編程支持的更新就是 Stream API,感興趣的可以瞭解下,官方文檔地址:https://docs.oracle.com/javase/8/docs/api/java/util/stream/package-summary.html
相比於以前的命令式編程,在 Java 中我個人現在更傾向於函數式編程的方法,它可以讓代碼的邏輯更清晰更優雅,比如同樣的邏輯用 Java 8 的 Stream 方式寫就是:
List<Number> results = collection.stream() .filter(n -> n > 5) .collect(Collectors.toList());
結束語:
以後會另起一篇專門整理下 Java 8 的函數式編程 Stream API 的用法,有興趣的朋友歡迎關註本博客,也歡迎大家留言討論。
我們處於大數據時代,對數據處理感興趣的朋友歡迎查看另一個系列隨筆:利用Python進行數據分析 基礎系列隨筆彙總
分享一張小鎮附近的小湖邊: