当编译器第一次编译失败的时候,会在当前的环境中查找能让代码编译通过的方法,用于将类型进行转换,实现二次编译。**
隐式函数
隐式转换可以在不需改任何代码的情况下,扩展某个类的功能。
隐式参数
普通方法或者函数中的参数可以通过 implicit 关键字声明为隐式参数,调用该方法时,就可以传入该参数,编译器会在相应的作用域寻找符合条件的隐式值。
隐式类
(1)其所带的构造参数有且只能有一个 (2)隐式类必须被定义在“类”或“伴生对象”或“包对象”里,即隐式类不能是顶级的。
当编译器第一次编译失败的时候,会在当前的环境中查找能让代码编译通过的方法,用于将类型进行转换,实现二次编译。**
隐式转换可以在不需改任何代码的情况下,扩展某个类的功能。
普通方法或者函数中的参数可以通过 implicit 关键字声明为隐式参数,调用该方法时,就可以传入该参数,编译器会在相应的作用域寻找符合条件的隐式值。
(1)其所带的构造参数有且只能有一个 (2)隐式类必须被定义在“类”或“伴生对象”或“包对象”里,即隐式类不能是顶级的。
协变:Son 是 Father 的子类,则 MyList[Son] 也作为 MyList[Father]的“子类”。 逆变:Son 是 Father 的子类,则 MyList[Son]作为 MyList[Father]的“父类”。 不变:Son 是 Father 的子类,则 MyList[Father]与 MyList[Son]“无父子关系”。
Scala 中的模式匹配类似于 Java 中的 switch 语法
模式匹配语法中,采用 match 关键字声明,每个分支采用 case 关键字进行声明,当需要匹配时,会从第一个 case 分支开始,如果匹配成功,那么执行对应的逻辑代码,如果匹配不成功,继续执行下一个分支进行判断。如果所有 case 都不匹配,那么会执行 case _分支, 类似于 Java 中 default 语句。
语法处理上和 Java 类似,但是又不尽相同。
注意事项
(1)Java 语言按照 try—catch—finally 的方式来处理异常
(2)不管有没有异常捕获,都会执行 finally,因此通常可以在 finally 代码块中释放资源。
(3)可以有多个 catch,分别捕获对应的异常,这时需要把范围小的异常类写在前面,把范围大的异常类写在后面,否则编译错误。