成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

fp->monadic

DC_er / 1270人閱讀

摘要:是可以被的容器類型。出自范疇論數(shù)學的一個分支滿足一些定律。滿足的定律是一種特殊的可以鋪平的結果。說明如果用普通第一層異常時會連續(xù)執(zhí)行通過的方式可以在異常發(fā)生時無論怎么最后還是它自己從而可以在異常發(fā)生時避免不必要的錯誤執(zhí)行。

functor

functor是可以被map over的容器類型。

關于這句話比較難理解的是,什么是map over?

(a -> b) -> f a -> f b 意思就是說一個a到b的映射,在接受a的functor之后,返回一個b的functor,下面是map over應用示例,可以結合著理解這句話。

const f= x => x.split("").reverse().join("");
const rs="olleh";
const b=f(rs);  
console.log(b); //hello


function JSDT(val) {
    this._val=val;
}
JSDT.prototype.map=function (f) {
    return new JSDT(f(this._val));
};
JSDT.of=function (val) {
    return new JSDT(val);
}
const fa=JSDT.of(rs);
const fb=fa.map(f);  
console.log(fb);   //JSDT {_val: "hello"}

說明 實現(xiàn)了map的container是Functor的實例(JSDT),map是將函數(shù)應用到container內部的方法。

functor出自范疇論(Category Theory),數(shù)學的一個分支,滿足一些定律。

fa.map(x => x) === fa;

fa.map(x => f(g(x))) === fa.map(g).map(f);

說明 關于這兩個定律下面有一個很好的理解例子

var a=[1,2,3].map(x => x);
console.log(a);  //[ 1, 2, 3 ]

const f= x => x+2;
const g= x => x*2;
var b1=[1,2,3].map(x => f(g(x)));
var b2=[1,2,3].map(g).map(f);
console.log(b1.toString()===b2.toString()); //true
Applicative Functor

Applicative本質是Functor的一種,可以將一個含有函數(shù)的容器應用到另一個容器中的值上。

JSDT.prototype.ap=function (container) {
    return container.map(this._val);
}
const f=JSDT.of(x => x+2);
let fy=f.ap(JSDT.of(3));
console.log(fy);  //JSDT { _val: 5 }

說明 Applicative的特性就是多了一層ap,示例中JSDT實例f中,this._val是抽象函數(shù)單元,可以應用到另一個匿名實例上。

applicative滿足的定律

a.of(x => x).ap(val) === val;

a.of(f).op(a.of(x)) === a.of(f(x));

u.ap(a.of(y)) === a.of(f => f(y)).ap(u);

Monad

Monad是一種特殊的Functor,可以Flat(鋪平)map的結果。

function Nothing() {
}
Nothing.prototype.map=function () {
    return this;
}
const nothing=new Nothing();
JSDT.prototype.flat=function () {
    return this._val;
}
JSDT.prototype.flatMap=function (f) {
    return this.map(f).flat();
}
let fm=JSDT.of({val:0}).
    flatMap(x => {
    if(x) return JSDT.of(x.val);
    else return nothing;
})
    .map(x => x+1)
    .map( x => 2/x);
console.log(fm);  //JSDT { _val: 2 }

說明 如果用普通map,第一層異常時,會連續(xù)執(zhí)行,通過monad的方式可以在異常發(fā)生時,無論怎么map最后還是它自己,從而可以在異常發(fā)生時避免不必要的錯誤執(zhí)行。

總結

monadic編程重要且普遍,典型的一種應用就是promise、還可以配合其它reactive編程框架使用,理解原理能幫助我們更好的使用。在深入過程中發(fā)現(xiàn)各種稀奇古怪的名詞,但耐心去分析和思考,也不難理解。

文章版權歸作者所有,未經(jīng)允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉載請注明本文地址:http://systransis.cn/yun/87056.html

相關文章

  • 和少婦白潔一起學JavaScript之Async/Await

    摘要:匿名函數(shù)是我們喜歡的一個重要原因,也是,它們分別消除了很多代碼細節(jié)上需要命名變量名或函數(shù)名的需要。這個匿名函數(shù)內,有更多的操作,根據(jù)的結果針對目錄和文件做了不同處理,而且有遞歸。 能和微博上的 @響馬 (fibjs作者)掰扯這個問題是我的榮幸。 事情緣起于知乎上的一個熱貼,諸神都發(fā)表了意見: https://www.zhihu.com/questio... 這一篇不是要說明白什么是as...

    Bryan 評論0 收藏0
  • Js-函數(shù)式編程

    摘要:組合組合的功能非常強大,也是函數(shù)式編程的一個核心概念,所謂的對過程進行封裝很大程度上就是依賴于組合。在理解之前,先認識一個東西概念容器容器為函數(shù)式編程里普通的變量對象函數(shù)提供了一層極其強大的外衣,賦予了它們一些很驚艷的特性。 前言 JavaScript是一門多范式語言,即可使用OOP(面向對象),也可以使用FP(函數(shù)式),由于筆者最近在學習React相關的技術棧,想進一步深入了解其思想...

    whinc 評論0 收藏0
  • 和少婦白潔一起學JavaScript之Async/Await II

    摘要:的科學定義是或者,它的標志性原語是。能解決一類對語言的實現(xiàn)來說特別無力的狀態(tài)機模型流程即狀態(tài)。容易實現(xiàn)是需要和的一個重要原因。 前面寫了一篇,寫的很粗,這篇講講一些細節(jié)。實際上Fiber/Coroutine vs Async/Await之爭不是一個簡單的continuation如何實現(xiàn)的問題,而是兩個完全不同的problem和solution domain。 Event Model 我...

    番茄西紅柿 評論0 收藏0
  • 翻譯連載 | 附錄 C:函數(shù)式編程函數(shù)庫-《JavaScript輕量級函數(shù)式編程》 |《你不知道的J

    摘要:為了盡可能提升互通性,已經(jīng)成為函數(shù)式編程庫遵循的實際標準。與輕量級函數(shù)式編程的概念相反,它以火力全開的姿態(tài)進軍的函數(shù)式編程世界。 原文地址:Functional-Light-JS 原文作者:Kyle Simpson-《You-Dont-Know-JS》作者 關于譯者:這是一個流淌著滬江血液的純粹工程:認真,是 HTML 最堅實的梁柱;分享,是 CSS 里最閃耀的一瞥;總結,...

    Miracle 評論0 收藏0
  • 嘗試在JavaScript中構建一個"Maybe"檢測器

    摘要:我的目的是確保所有引用的使用都是絕對安全的,編譯器會自動進行檢查。它導致了數(shù)不清的錯誤漏洞和系統(tǒng)崩潰,可能在之后年中造成了十億美元的損失。這個函數(shù)將使用一個表示我們希望進行轉換的函數(shù)參數(shù),并返回一個包含轉換結果的新參數(shù)。 翻譯原文出處:Building a Maybe in JavaScript 鄙人翻譯略差且略有出入,別見笑。 很多時候我們會碰到:Uncaught TypeError...

    bingo 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<