成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

函數式編程術語解析

開發 前端
一個純函數需要滿足兩個條件,第一是函數的返回值只能由輸入值(函數接收的參數)決定,也就是說純函數接收相同的參數會返回相同的值;第二是純函數不會對自身作用域之外的運環境產生副作用(side effects)。

[[174906]]

Arity

指函數的參數數量,由 -ary 和 -ity 這兩個英文后綴拼接而成:

  1. const sum = (a, b) => a + b; 
  2. const Arity = sum.length; 
  3. console.log(Arity); 
  4. // 輸出結果為 2  

Higher-Order Functions

高階函數,此類函數可以接收其他函數作為參數,也可以返回一個函數作為返回值:

  1. const filter = (predFunc, list) => { 
  2.   const results = []; 
  3.   list.forEach((listItem) => { 
  4.     if (predFunc(listItem)) { 
  5.       results.push(listItem); 
  6.     } 
  7.   }); 
  8.   return results; 
  9. // filter 這個函數就是將一個函數作為參數傳入 
  10. // 但這都么有什么,主要是后面is函數返回一個函數 
  11.  
  12. const is = (type) => (x) => Object(x) instanceof type; 
  13. // is這個函數就是將一個函數作為返回值返回到下面的調用之中 
  14.  
  15. filter(is(Number), [0, '1', 2, null]); 
  16. // 上面函數調用的結果是 [0, 2]  

Partial Application

偏函數,在原函數的基礎上預填充(pre-filling)部分參數并返回的新函數:

  1. // 下面是一個創建偏函數的輔助函數,下面函數將一個函數和這個函數所需要 
  2. // 的除了***一個參數的參數傳入,返回一個新的函數,這個新的函數的參數為原 
  3. // 函數的***一個參數 
  4. const partial = (func, ...args) => (...moreArgs) => func(...args, ...moreArgs); 
  5. // 寫一個將三個數字相加的函數 
  6. const add3 = (a, b, c) => a + b + c; 
  7. // 預填充 (add3, 2, 3) 三個參數,空置***一個參數,返回一個新的函數,重點是返回一個新的函數 
  8. const fivePlus = partial(add3, 2, 3); // (c) => 2 + 3 + c 
  9. fivePlus(4); 
  10. // => 9  

Currying

柯里化,將一個接收多個參數的函數轉化為單參數函數的方式,轉化后的函數每次只接收一個參數,然后返回一個新函數,新函數可以繼續接收參數,直到接收到所有的參數:

  1. const sum = (a, b) => a + b; 
  2. sum(2, 3); 
  3. // => 6 
  4. const curriedSum = (a) => (b) => a + b; 
  5. curriedSum(40)(2); 
  6. // => 42. 
  7. const add2 = curriedSum(2); 
  8. // (b) => 2 + b 
  9. add2(10); 
  10. // => 12  

Function Composition

函數合成,接收多個函數作為參數并返回一個新函數的方式,新函數按照傳入的參數順序,從右往左依次執行,前一個函數的返回值是后一個函數的輸入值:

  1. const compose = (f, g) => (a) => f(g(a)); 
  2. const floorAndToString = compose((val) => val.toString(), Math.floor); 
  3. floorAndToString(121.212121); 
  4. // => "121"  

Purity

一個純函數需要滿足兩個條件,***是函數的返回值只能由輸入值(函數接收的參數)決定,也就是說純函數接收相同的參數會返回相同的值;第二是純函數不會對自身作用域之外的運環境產生副作用(side effects),比如說不會改變外部環境中變量的值,這會被認為是不安全的行為:純函數示例:

  1. const greet = (name) => "Hi, " + name ; 
  2. greet("Brianne"
  3. // => "Hi, Brianne"  

Side effects

如果函數或表達式與其自身作用域之外的可變數據(mutable data)發生了讀寫操作,那么此時函數和表達式就產生了副作用:

  1. let greeting; 
  2. const greet = () => greeting = "Hi, " + window.name
  3. // greet() 執行時更改了外部環境的變量 
  4. greet(); 
  5. // => "Hi, Brianne" 
  6. // new Date() 是可變數據 
  7. const differentEveryTime = new Date();  

Point-Free Style

point-free style 是一種不顯式向函數傳遞參數的代碼風格,通常需要柯里化和高階函數來實現:

  1. const map = (fn) => (list) => list.map(fn); 
  2. const add = (a) => (b) => a + b; 
  3. // Not points-free 
  4. // numbers 是一個顯式傳遞的參數 
  5. const incrementAll = (numbers) => map(add(1))(numbers); 
  6. // Points-free 
  7. // add(1) 的返回值隱式傳遞給了 map,作為 map 的 list 參數 
  8. const incrementAll2 = map(add(1));  

Predicate

斷言,一個返回布爾值的函數:

  1. const predicate = (a) => a > 2; 
  2. [1, 2, 3, 4].filter(predicate); 
  3. // => [3, 4]  

Constant

常量,初始化后不能再次執行賦值操作的數據類型:

  1. const five = 5; 
  2. const john = { name'John', age: 30 }; 
  3. // 因為常量不可變,所以下面表達式一定為 true 
  4. john.age + five === ({ name'John', age: 30 }).age + (5);  

常量具有 referentially transparent 的特性,也就是說將程序中出現的常量替換為它們實際的值,并不會影響程序的結果。譯者話外:實際上在 JavaScript 中的 const 所聲明的常量并不是完全穩定的,使用 Immutable.js 演示更加恰當:

  1. // 這里的fromJS(), get()函數都是immutable.js所提供的方法 
  2. const five = fromJS(5); 
  3. const john = fromJS({name'John', age: 30}); 
  4. john.get('age') + five === ({ name'John', age: 30 }).age + (5);  

Functor

functor 都擁有 map 函數,并且在執行 map 之后會返回一個新的 functor:

  1. object.map(x => x) === object; 
  2.  
  3. object.map(x => f(g(x))) === object.map(g).map(f);  

JavaScript 中最常見的 functor 就是數組類型的實例:

  1. [1, 2, 3].map(x => x); 
  2. // => [1, 2, 3] 
  3. const f = x => x + 1; 
  4. const g = x => x * 2; 
  5. [1, 2, 3].map(x => f(g(x))); 
  6. // => [3, 5, 7] 
  7. [1, 2, 3].map(g).map(f);      
  8. // => [3, 5, 7]  

Lift

lift 發生在你將值放入 functor 的時候,如果你將函數 lift 進了 Applicative Functor,那么就可以使用這個函數處理傳遞給這個 functor 的值。某些 lift 的實現擁有 lift 或 liftA2 函數,便于在 functor 上執行相關的函數:

  1. const mult = (a, b) => a * b; 
  2. const liftedMult = lift(mult); 
  3. // => this function now works on functors like array 
  4. liftedMult([1, 2], [3]); 
  5. // => [3, 6] 
  6. lift((a, b) => a + b)([1, 2], [3, 4]); 
  7. // => [4, 5, 5, 6]  

lift 一個單參數的函數非常類似于 map 操作:

  1. const increment = (x) => x + 1; 
  2. lift(increment)([2]); 
  3. // => [3] 
  4. [2].map(increment); 
  5. // => [3]  
責任編輯:龐桂玉 來源: segmentfault
相關推薦

2013-09-09 09:41:34

2011-03-08 15:47:32

函數式編程

2020-09-24 10:57:12

編程函數式前端

2025-03-11 10:00:20

Golang編程函數

2011-08-24 09:13:40

編程

2023-12-14 15:31:43

函數式編程python編程

2022-09-22 08:19:26

WebFlux函數式編程

2017-06-08 14:25:46

Kotlin函數

2010-11-25 09:06:37

Web開發函數式編程

2009-11-19 13:15:09

UPS專業術語

2020-09-23 07:50:45

Java函數式編程

2010-03-11 10:34:22

Scala

2012-09-21 09:21:44

函數式編程函數式語言編程

2020-09-22 11:00:11

Java技術開發

2016-08-11 10:11:07

JavaScript函數編程

2016-08-11 10:34:37

Javascript函數編程

2019-09-09 11:40:18

編程函數開發

2022-07-07 09:03:36

Python返回函數匿名函數

2012-03-21 09:30:11

ibmdw

2024-02-28 08:37:28

Lambda表達式Java函數式接口
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产一区二区三区欧美 | 国产精品视频一二三区 | 好好的日在线视频 | 精品欧美一区二区三区久久久小说 | 欧美区在线观看 | 国产精品视频一区二区三区 | 国产高清精品一区二区三区 | 中文字幕一区二区三区四区 | 一区二区三区在线 | 超碰人人人人 | 成人精品一区二区三区中文字幕 | 亚洲九九色 | 欧美一区二区三区的 | 91视频在线 | 97久久精品午夜一区二区 | 91麻豆精品国产91久久久久久久久 | 日本精品视频一区二区三区四区 | 久久久精品一区二区三区 | 国产亚洲精品精品国产亚洲综合 | 国产精品久久久久久久久久久久久久 | 热久久性 | 久久精品国产久精国产 | 精品在线免费看 | 成人在线一区二区 | 欧美视频区 | 久久久九九 | 亚洲精品v | 久久一二| 国产95在线 | av大片 | 黄色大片观看 | 亚洲影音先锋 | 天天干夜夜操 | 午夜成人免费视频 | 一级a爱片久久毛片 | 九九热在线视频免费观看 | 国产在线成人 | 国户精品久久久久久久久久久不卡 | 国产精品日韩高清伦字幕搜索 | 国产激情在线 | 福利久久|