这篇文章将为大家详细讲解有关怎么在scala中使用隐式转换与隐式参数,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。
隐式转换和隐式参数
Scala总共有三个地方会使用隐式定义:
转换到一个预期的类型
对某个(成员)选择接收端(字段、方法调用等)的转换
隐式参数
隐式规则
标记规则:只有标记为implicit的定义才可用。可标记任何变量、函数、对象
作用域规则:被插入的隐式转换必须是当前作用域的单个标识符,或者跟隐式转换的源类型或目标类型有关联
每次一个规则:每次只能有一个隐式定义被插入
比如编译器绝不会将x+y重写为convert2(convert1(x))+y
显示优先规则:只要代码按编写的样子能通过类型检查,就不尝试隐式定义
隐式转到到一个预期的类型
写过HBase的时候,都知道要写大量的Bytes.toBytes()吧,那么使用隐式转换吧。
object HBasePref {
implicit def Str2Bytes(value: Any): Array[Byte] = value match {
case str: String => Bytes.toBytes(str)
case long: Long => Bytes.toBytes(long)
case double:Double => Bytes.toBytes(double)
}
implicit def str2HBaseTableName(str: String): TableName = TableName.valueOf(str)
}
与新类型互相操作
你期望能够运行1 + new Rational(1,2)这个代码,但int类型显然没有这个方法。用隐式转换吧
implicit def intToRational(x:Int) = new Rational(1,1)
模拟新的语法
还记得Map初始化的->标识符吗?这么骚的操作也是隐式转换干的
隐式类
如果你经常要构造某个类,那么隐式的骚操作就可以这么干。
case class Rectangle(width,height)
implicit class RectangleMaker(width:Int) {
def x(height:Int) = Rectangle(width,height)
}
val myRectangle = 3 x 4
隐式参数
class PreferredPromt(val preference:String)
object JoesPrefs {
implicit val promt = new PreferredPrompt("Yes master>")}
object Greeter {
def greet(name:String)(implicit prompt:PreferredPromt) = {
println("Welcome," + name)
println(prompt.preference)
}
}
import JoesPrefs._
Greeter.greet("ljk")
关于怎么在scala中使用隐式转换与隐式参数就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。