阿川私房教材:學程式,拿 offer!

63 個專案實戰,直接上手!
無需補習,按步驟打造你的面試作品。

立即解鎖你的轉職秘笈

函數式程式設計因其提供高效可擴展的解決方案的能力而受到歡迎。這是一種聲明式程式設計方法,重點是指定程式應該完成什麼,而不是如何完成它。

在這篇文章中,我們將研究函數式程式設計的核心概念和優點,並探討一些最受歡迎的函數式程式語言。

我們開始吧

什麼是函數式程式設計?

函數式程式設計是一種聲明式程式設計範式,專注於依序應用純函數來解決複雜問題。它將函數視為一等公民,允許它們作為參數傳遞給其他函數,作為函數的值返回,並儲存在資料結構中。

👉函數式程式設計擅長數學函數,其中值沒有任何相關性,並且不使用物件導向程式設計中使用的共享狀態和可變資料等概念。

功能性的

函數式程式設計的核心概念

1️⃣first class citizen

函數被視為資料類型變數,可以像任何其他變數一樣使用。

範例:JavaScript中,我們可以將一個函數作為參數傳遞給另一個函數,就像傳遞變數一樣。

function add(x, y) {
  return x + y;
}

function multiply(x, y) {
  return x * y;
}

function calculator(operation, x, y) {
  return operation(x, y);
}

console.log(calculator(add, 2, 3)); // Output: 5
console.log(calculator(multiply, 2, 3)); // Output: 6

在此範例中, calculator函數將另一個函數(加法或乘法)作為參數,並使用它來執行計算。

2️⃣遞歸

函數式程式避免在每次執行時建立不同輸出的結構。相反,遞歸函數會重複呼叫自身,直到達到所需的狀態或解決方案(稱為基本情況)。

範例:Python中,我們可以使用遞歸來計算數字的階乘。

def factorial(n):
  if n == 0:
    return 1
  else:
    return n * factorial(n-1)

print(factorial(5)) // Output: 120

在此範例中, factorial函數重複呼叫自身,直到到達基本情況(n == 0) ,此時它會傳回最終結果。

3️⃣不變性

變數建立後不能修改。這確保了程式的狀態在整個執行期間保持不變。

範例:Haskell中,我們可以建立一個不可變列表,然後使用函數建立一個元素經過轉換的新列表。

myList = [1, 2, 3, 4, 5]

doubleList = map (*2) myList

print doubleList // Output: [2, 4, 6, 8, 10]

在這個範例中, myList變數是不可變的,我們透過將map函數應用於 myList 來建立一個新清單doubleList 。原名單不變。

4️⃣純函數

如果給定的輸入相同且沒有副作用,純函數會產生相同的輸出。

範例:JavaScript中,我們可以建立一個純函數,它將字串作為輸入並傳回刪除所有元音的字串。

function removeVowels(str) {
  return str.replace(/[aeiou]/gi, '');
}

console.log(removeVowels("Hello World")); // Output: "Hll Wrld"
console.log(removeVowels("Hello World")); // Output: "Hll Wrld"

在此範例中, removeVowels函數採用字串作為輸入,並傳回刪除所有元音的新字串。該函數沒有副作用,並且在給定相同輸入的情況下始終返回相同的輸出。

5️⃣高階函數

接受其他函數作為參數或返回函數作為輸出的函數。

範例:Python中,我們可以建立一個高階函數,它將另一個函數作為參數並將其應用於數字列表。

def applyFunction(func, numbers):
  return [func(x) for x in numbers]

def double(x):
  return x * 2

def square(x):
  return x * x

numbers = [1, 2, 3, 4, 5]

print(applyFunction(double, numbers)) // Output: [2, 4, 6, 8, 10]
print(applyFunction(square, numbers)) // Output: [1, 4, 9, 16, 25]

在此範例中, applyFunction函數採用另一個函數(雙精確度或平方)作為參數,並將其應用於數字清單。該函數傳回一個新列表,其中包含將函數應用於每個數字的結果。

函數式程式設計的優點

  1. 易於除錯:純函數產生與給定輸入相同的輸出,從而更容易檢查程式碼中的錯誤。

  2. 惰性求值:僅在需要時才求值,減少不必要的計算。

  3. 支援並行編程:不可變變數可以輕鬆建立平行程序,減少程式內的變更量。

  4. 易於閱讀:函數易於閱讀和理解,從而更容易理解程式碼庫和用途。

  5. 高效能:函數式程式不依賴外部來源或變數,使它們可以輕鬆地在程式中重複使用。

函數式程式設計的缺點

  1. 術語問題:函數式程式設計有很多術語,外行人可能很難解釋。

  2. 遞歸:雖然遞歸是一個強大的功能,但它的使用成本可能很高,需要更高的記憶體使用量。

流行的函數式程式語言

  1. Haskell :一種專為函數式程式設計的靜態型別程式語言。

  2. Python :儘管 Python 是為物件導向程式設計而設計的,但它支援函數式程式設計功能,例如 lambda 表達式和屬性。

  3. Erlang :一種最適合併發系統的函數式程式語言,由 WhatsApp 和 Discord 等訊息應用程式使用。

  4. JavaScript :支援 lambda 表達式和屬性等函數式程式設計功能,使其成為多範式語言中的流行選擇。

  5. Clojure :函數式程式語言,提供避免可變狀態的工具,支援可變和不可變資料類型。

  6. Scala :一種同時支援函數式和物件導向程式設計的語言,旨在解決 Java 的缺點。

  7. Rust :一種系統程式語言,支援不變性和遞歸等函數式程式設計概念。

  8. Swift :Apple 開發的現代程式語言,支援閉包和高階函數等函數式程式設計功能。

  9. F# :由 Microsoft 開發的函數式程式語言,是 .NET 生態系統的一部分。

  10. Lisp :基於函數式程式設計概念的程式語言系列,包括Scheme 和Common Lisp。

  11. OCaml :INRIA 開發的函數式程式語言,用於各種應用程式,包括 Web 開發和科學計算。

  12. R :一種用於統計計算和圖形的程式語言和環境,支援閉包和高階函數等函數式程式設計概念。

  13. Julia :一種高效能程式語言,支援不變性和遞歸等函數式程式設計概念。

  14. Kotlin :JetBrains 開發的現代程式語言,支援 lambda 表達式和高階函數等函數式程式設計功能。

  15. TypeScript :微軟開發的靜態型別程式語言,支援 lambda 表達式和高階函數等函數式程式設計功能。

**注意:**還有許多其他程式語言支援函數式程式設計概念。

駭客

結論

函數式程式設計是一種強大的範例,可為複雜的業務問題提供高效且可擴展的解決方案。透過了解函數式程式設計的核心概念和優勢,開發人員可以解鎖解決問題的新方法,並增加在全球人才庫中脫穎而出的機會。無論您是經驗豐富的程式設計師還是剛起步的程式設計師,函數式程式設計絕對值得探索。

重點總結

  • 函數式程式設計是一種聲明式程式設計範式,專注於依序應用純函數來解決複雜問題。

  • 函數式程式設計的核心概念包括一等函數、遞歸、不變性、純函數和高階函數。

  • 函數式程式設計的優點包括易於除錯、惰性求值、支援並行編程、易於閱讀和高效能。

  • 函數式程式設計的缺點包括術語問題和遞歸。

  • 流行的函數式程式語言包括 Haskell、Python、Erlang、JavaScript、Clojure 和 Scala。


歡迎對本文進行任何更正或補充。

感謝您的閱讀

Happy Coding😎


原文出處:https://dev.to/dhanush9952/a-guide-to-functional-programming-18h9

按讚的人:

共有 0 則留言


精選技術文章翻譯,幫助開發者持續吸收新知。

阿川私房教材:學程式,拿 offer!

63 個專案實戰,直接上手!
無需補習,按步驟打造你的面試作品。

立即解鎖你的轉職秘笈