Implementation of scala set.contains

前端 未结 2 1223
礼貌的吻别
礼貌的吻别 2021-01-19 19:21
type Set = Int => Boolean
/**
* Indicates whether a set contains a given element.
*/
def contains(s: Set, elem: Int): Boolean = s(elem)

Why does

相关标签:
2条回答
  • 2021-01-19 19:56

    Taking this piece by piece, the type alias in the first line means that we can rewrite the second line as follows:

    def contains(s: Int => Boolean, elem: Int): Boolean = s(elem)
    

    But A => B is just syntactic sugar for Function1[A, B], so we can do more rewriting:

    def contains(s: Function1[Int, Boolean], elem: Int): Boolean = s(elem)
    

    s(elem) is also syntactic sugar—any time you "apply" a value to a value in this way, Scala desugars it to s.apply(elem):

    def contains(s: Function1[Int, Boolean], elem: Int): Boolean = s.apply(elem)
    

    And if you look at the apply method on Function1 you'll see that the types line up.

    So that's it—we're just representing the set as its indicator function and then burying that under three layers of syntactic sugar.


    Update to address the comment: representing a set as its indicator function makes it possible to model infinite sets (and lots of other sets) much more naturally than the usual list-based representation. Suppose I want a set of all odd numbers, for example. Using the representation you have here, this is easy:

    val odds: Set[Int] = (_ % 2 != 0)
    

    Try doing the same thing with HashSet, for example.

    0 讨论(0)
  • 2021-01-19 20:20

    Set here is a function from Int to Boolean, so calling s(someInt) returns a boolean, you have of course to provide that function:

    def contains(s: Set, elem: Int): Boolean = s(elem)
    
    contains({ someInt => someInt == 1 }, 1) // returns true
    
    0 讨论(0)
提交回复
热议问题