主要的編程範式有三種:命令式編程,聲明式編程和函數式編程。html
命令式編程:java
命令式編程的主要思想是關注計算機執行的步驟,即一步一步告訴計算機先作什麼再作什麼。編程
好比:若是你想在一個數字集合 collection(變量名) 中篩選大於 5 的數字,你須要這樣告訴計算機:api
代碼實現以下:數據結構
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 等等,你均可以以這個方式寫。閉包
聲明式編程:oracle
聲明式編程是以數據結構的形式來表達程序執行的邏輯。它的主要思想是告訴計算機應該作什麼,但不指定具體要怎麼作。編程語言
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進行數據分析 基礎系列隨筆彙總
分享一張小鎮附近的小湖邊: