zoukankan      html  css  js  c++  java
  • [Functional Programming 101] runWIth, evalWith, execWith

    Recentlly, I am learning crocks.js ADT libaray. In the beginning, it is hard to understand when to use 'runWith', 'evalWith', 'execWith'. Until I went though the course a thrid times... I finally have some feelings for it.

    State has 'get, put, modify' methods for use, and you can build them by yourself as well:

    // getState :: () -> State s
    const getState = () => State(s => Pair(s, s))
    
    //putState :: s -> State s ()
    const putState = state => State(() => Pair(Unit(), state));
    
    // modifyState :: (s -> s) -> State s ()
    const modifyState = fn => State(s => Pair(Unit(), fn(s)));

    As well can see, for those methods, they are all using 'Pair'.

    Pair(a, s):

    On the left part of Pair, is 'a': stand for variable; On the right part of Pair, 's' is the State.

    Now rules for using 'runWith', 'evalWith', 'execWith':

    1. If you want to get result as Pair(a, s), you should use 'runWith':

    const bubble = {
        bubbles: 40
    };
    const add = x => y => x+ y;
    console.log(
        modify(mapProps({bubbles: add(1)}))
            .runWith(bubble) // Pair( (), { bubbles: 41 } )
    )

    2. If you only instreaded in the variable 'a', you should use 'evalWith':

    const bubble = {
        bubbles: 40
    };
    const add = x => y => x+ y;
    console.log(
        modify(mapProps({bubbles: add(1)}))
            .evalWith(bubble) // () Unit
    )

    3. If you instested in State, which is on the right part of Pair, you should use 'execWith':

    const bubble = {
        bubbles: 40
    };
    const add = x => y => x+ y;
    console.log(
        modify(mapProps({bubbles: add(1)}))
            .execWith(bubble) // { bubbles: 41 }
    )
  • 相关阅读:
    BoundsChecker下载
    大型系统内部资源定位的途径
    架构的焦点
    为什么日志只应该有三个级别
    回收站引发ORACLE查询表空间使用缓慢
    题目记录
    广搜入门 待改进的广搜
    归并排序的使用
    大数数组中滚动数组的应用
    多重背包问题
  • 原文地址:https://www.cnblogs.com/Answer1215/p/10334960.html
Copyright © 2011-2022 走看看