zoukankan      html  css  js  c++  java
  • Scala 上下文界定

    上下文界定的类型参数形式为T:M的形式,其中M是一个泛型,这种形式要求存在一个M[T]类型的隐式值:

      /**
        * 上下文界定
        */
      @Test
      def testOrdering_Class_Context() = {
        class User(val userName: String, val age: Int)
    
        class UserOrderingObject extends Ordering[User] {
          override def compare(x: User, y: User): Int = x.age - y.age
        }
    
        class Pair[T: Ordering](val first: T, val second: T) {
          def smaller(implicit ord: Ordering[T]) = {
            if (ord.compare(first, second) > 0)
              second
            else
              first
          }
        }
    
        val u1 = new User("u1", 12)
        val u2 = new User("u2", 13)
        //提供隐式值,隐式值需要提供在创建Pair之前
        implicit val uo = new UserOrderingObject
        val p = new Pair(u1, u2)
    
        println(p.smaller.age)
    
    
      }
    
      /**
        * 上下文界定
        */
      @Test
      def testOrdering_Object_Context_1() = {
        class User(val userName: String, val age: Int)
    
        //TODO 隐式object伴生对象
        implicit object UserOrderingObject extends Ordering[User] {
          override def compare(x: User, y: User): Int = x.age - y.age
        }
    
        class Pair[T: Ordering](val first: T, val second: T) {
          def smaller() = {
            //TODO 获取隐式对象
            val ord = implicitly[Ordering[T]]
            if (ord.compare(first, second) > 0)
              second
            else
              first
          }
        }
    
        val u1 = new User("u1", 12)
        val u2 = new User("u2", 13)
        // 有隐式伴生对象不再需要提供隐式值
        val p = new Pair(u1, u2)
    
        println(p.smaller.age)
    
    
      }
    
    
      /**
        * 上下文界定
        */
      @Test
      def testOrdering_Object_Context_2() = {
        class User(val userName: String, val age: Int)
    
    
         object UserOrderingObject extends Ordering[User] {
          override def compare(x: User, y: User): Int = x.age - y.age
        }
    
        class Pair[T: Ordering](val first: T, val second: T) {
          def smaller() = {
    
            val ord = implicitly[Ordering[T]]
            if (ord.compare(first, second) > 0)
              second
            else
              first
          }
        }
    
        val u1 = new User("u1", 12)
        val u2 = new User("u2", 13)
        implicit val uo = UserOrderingObject
        val p = new Pair(u1, u2)
    
        println(p.smaller.age)
    
    
      }
  • 相关阅读:
    js单体模式
    react实现递归搜索下拉查询目录树功能
    浏览器跨域问题分析
    css中清除浮动
    ts中的函数
    ts中类型
    RX.js6变化
    js对象模型3
    React数组变化之后,视图没有更新
    Mac安装yarn并配置环境变量PATH,运行报错问题解决
  • 原文地址:https://www.cnblogs.com/leodaxin/p/7534726.html
Copyright © 2011-2022 走看看