Scala 语言学习之泛型(7)

简介:

==> 泛型类

        ---> T 可以代表任意类型

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
class  Person[T]{
   private  var  name : =  _
 
   def  setName(name : T)  =  { this .name  =  name}
   def  getName() : =  { this .name}
}
 
// ***********测试*****************
object  Person{
   def  main(args : Array[String]) : Unit  =  {
     var  =  new  Person[String]()
     p.setName( "hello" )
     println(p.getName())
   }
}


==> 泛型函数

        ---> 类型参数放在方法名之后

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
//* 泛型函数
// 创建一个固定类型的数组
// 普通函数
def  mkInt(elems : Int*)  =  Array[Int](elems :_ *)
def  mkString(str : String*)  =  "mkString"
 
// 使用泛型函数,可以接收任意类型
def  mkArray[T : ClassTag](elems : T*)  =  Array[T](elems :_ *)
 
// ***********测试*****************
// 普通函数只能传入相对应类型的参数
mkInt( 1 , 2 , 3 )
mkString( "hello" "world" )
 
// 泛型函数可以传入任意类型的参数
mkArray( 11.26 , 665 84 "hello" )


==> 类型的上界和下界(Upper Bounds 和 Lower Bounds)

        ---> 用来定义泛型变量的范围 :  

        ---> S <: T  (上界)        S 必须是 T 类型的子类类本身

1
2
3
4
5
6
7
8
9
10
class  Person 1 {
   def  gender()  =  {println( "gender" )}
}
 
class  Man  extends  Person 1 {
   override  def  gender()  =  {println( "man" )}
}
 
class  Women  extends  Person 1 {
   override  def  gender()  =  {println( "women" )}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
object  UpperBoundsAndLowerBounds {
   // 定义一个泛型函数,通过上界的方式指定泛型的范围必须是 Person1 的子类或者Person1 类,并调用类中的 gender 方法
   def  getGender[T < :  Person 1 ](g : T)  =  {g.gender()}
 
   def  main(args : Array[String]) :  Unit  =  {
     // 创建一个Person1 对象 ,调用getGender 方法调用 Personal 中的 gender 方法
     var  p : Person 1  =  new  Person 1
     getGender(p)
 
     // 创建一个 Man 对象 ,通过 getGender 方法调用Man 类中的 gender 方法
     var  =  new  Man
     getGender(m)
   }
 
}


        ---> U >: T(下界)        U 必须是 T 类型的父类类本身,此处不作示例,与上面例子类似,只是传入 getGender 方法中的参数必须是 Person1 类其父类的对象


==> 视图界定    <%

        ---> 与类型的上界相似,但是比类型的上界适用范围更广,除了所有的子类与类本身,它还允许通过隐式转换得到的类型

1
2
3
4
5
6
7
8
def  int 2 String[T < %  String](x : T, y : T)  =  {
   println(x +  "*****"  + y)
}
 
// ***********测试*****************
int 2 String( "hello" "world" )
implicit  def  int 2 String 1 (n : Int) : String  =  {n.toString}
int 2 String( 100 120 )


==> 协变和逆变

        ---> 协变: 泛型变量的值可以是子类类本身     在类型参数前加一个 “+” 符号    转换为父类

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
//* 协变和逆变   在类型的前面加入 +号,就可以使类的特征变为协变了
// 将子类对象转换为父类对象称为协变 +
// 将父类对象转换为子类对象称为逆变 -
package  demo 1 {
   // 父类
   class  Animal{}
   // 子类
   class  Bird  extends  Animal
   class  Sparrow  extends  Bird
   
   // 吃东西的类      协变
   class  EatSomethings[+T](t : T){}
 
   // ***********测试*****************
   object  Demo 1 {
 
     def  main(args : Array[String]) :  Unit = {
       // 创建一个吃东西的对象
       var  c 1 : EatSomethings[Sparrow]  =  new  EatSomethings[Sparrow]( new  Sparrow)
 
       var  c 2 : EatSomethings[Animal]  =  c 1
     }
   }
}


        ---> 逆变: 泛型变量的值可以是父类类本身    在类型参数前加一个 “ ” 符号    父类转换为子类    例:省略


==> 隐式转换函数    

        ---> 以关键字  implicit   申明

        ---> 单个参数

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
class  Fruit(name : String){
   def  getFruitName() : String  =  {name}
}
 
class  Monkey(f : Fruit){
   def  say()  =  {println( "Monkey like "  + f.getFruitName()) }
}
 
// ***********测试*****************
object  ImplicitDemo {
   def  main(args : Array[String]) : Unit  =  {
     var  f : Fruit  =  new  Fruit( "bnanan" )
 
     // 调用 fruit 的方法,希望 Monkey这个say 方法来实现
     // 需要将 fruit 的对象转换为 monkey 对象, 即定义一个隐匿转换函数
     implicit  def  fruit 2 Monkey(f : Fruit) : Monkey  =  { new  Monkey(f)}      // 将 fruit 对象转换为 Monkey 对象
     // 调用Monkey中的 say 方法
     f.say()
   }
}


==> 隐式参数    使用 implicit 关键字申明的函数参数

        ---> 可以使用隐式参数进行类型转换

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
// 隐式参数
def  testParam( implicit  name : String)  =  {println( "The value is "  + name)}
implicit  val  name : String  =  "这是一个隐式值"
 
// ***********测试*****************
testParam
//---------------------------------------------------------------
 
// 带隐式参数的泛型函数
// Ordered[T] 使类型可排序,
//     原型:def smaller
// (implicit order:T      =>    Ordered[T])
def  smaller[T](a : T, b : T)( implicit  order : = > Ordered[T])  =  if (order(a) < b) a  else  b
 
// ***********测试*****************
smaller( 100 56 )
smaller( "hello" "hi" )


==> 隐式类    对类  增加 implicit 限定 的类,其主要作用就是对类的功能增强

        ---> 编写一个隐式类,使类实现更多的功能

1
2
3
4
5
6
7
8
9
10
11
12
object  testImplicit {
 
   // 定义一个隐式类
   implicit  class  Calc(x : Int){
     def  add(a : Int) : Int  =  a + x
   }
 
   // ***********测试*****************
   def  main(args : Array[String]) : Unit  =  {
     println( "两个数字的和:"  1 .add( 2 ))
   }
}

        ---> 程序过程分析:

                --- 当 1.add(2)时,scala 的编译器不会报错,在当前域中查找,有没有 implicit 修饰的,同时可以将 Int 作为参数的构造器,并且具有 add 方法的类,通过查找,找到 Calc

                --- 利用隐式类 Calc 来执行 add 方法


==> 个人总结:

        ---> 通过泛型,可以使我们定义一个模具,就像蛋糕的模具,我们可以分别放入草莓,蓝莓等不同的原料加工出不同口味的蛋糕来

        ---> 通过使用 上界,下界,视图界定,协变,逆变,对泛型的范围制定规则,使我们可以传入的符合规则的参数

        ---> 隐式函数,隐式参数,隐式类,会在程序运行时首先被查找,若有符合 以 implicit 修饰的参数,函数以及类,先执行,然后才运行程序


若总结有误,还请多多指教,谢谢!!!

本文转自   tianshuai369   51CTO博客,原文链接:http://blog.51cto.com/songqinglong/2072568

相关文章
|
3月前
|
分布式计算 大数据 Java
大数据-87 Spark 集群 案例学习 Spark Scala 案例 手写计算圆周率、计算共同好友
大数据-87 Spark 集群 案例学习 Spark Scala 案例 手写计算圆周率、计算共同好友
87 5
|
3月前
|
分布式计算 关系型数据库 MySQL
大数据-88 Spark 集群 案例学习 Spark Scala 案例 SuperWordCount 计算结果数据写入MySQL
大数据-88 Spark 集群 案例学习 Spark Scala 案例 SuperWordCount 计算结果数据写入MySQL
64 3
|
2月前
|
消息中间件 分布式计算 Java
Scala语言发展历史及基本常识
Scala,由马丁·奥德斯基于2001年创造,融合了Java和JavaScript的特性,被称为“大数据的黄金语言”。它是Spark、Flink、Kafka等项目的主要开发语言,运行在JVM上,与Java高度兼容,支持面向对象和函数式编程。Scala以精简的语法和高级语言特性著称,成为大数据处理领域的首选语言之一。
|
5月前
|
监控 安全 Java
Scala 语言助力局域网监控电脑屏幕软件的创新
在数字化办公时代,局域网监控软件对企业和信息安全至关重要。Scala语言融合了面向对象与函数式编程,其简洁的语法和强大的类型系统为这类软件的开发提供了新机遇。利用Scala的函数式编程特性,开发者能编写更简洁、易维护的代码;结合Java的丰富类库,实现高效网络通信;Scala的并发模型还能优化多线程处理,提升监控效率。这些特点使Scala成为开发智能且高效的局域网监控软件的理想选择。
33 0
|
6月前
|
分布式计算 大数据 Java
大数据开发语言Scala入门
大数据开发语言Scala入门
|
6月前
|
IDE 大数据 Java
「AIGC」大数据开发语言Scala入门
Scala,融合OOP和FP的多范式语言,在JVM上运行,常用于大数据处理,尤其与Apache Spark配合。要开始学习,安装Scala,选择IDE如IntelliJ。基础包括变量、数据类型、控制结构、函数。Scala支持类、对象、不可变数据结构、模式匹配和强大的并发工具。利用官方文档、教程、社区资源进行学习,并通过实践提升技能。
86 0
|
7月前
|
编译器 Scala
scala-柯里化、隐式转换、泛型、upperbound、viewbound、contextBound
scala-柯里化、隐式转换、泛型、upperbound、viewbound、contextBound
42 0
|
8月前
|
Scala 容器
Scala学习--day04--集合、常用方法、案例实操 - WordCount TopN、不同省份的商品点击排行
Scala学习--day04--集合、常用方法、案例实操 - WordCount TopN、不同省份的商品点击排行
113 2
|
8月前
|
消息中间件 分布式计算 大数据
Scala学习--day03--函数式编程
Scala学习--day03--函数式编程
111 2
|
8月前
|
Java Scala
Scala学习--day02---控制流、“九层妖塔—杨辉三角”
Scala学习--day02---控制流、“九层妖塔—杨辉三角”
207 1