大数据教程Scala系列之继承-创新互联
1. 扩展类
在Scala中扩展类的方式和Java一样都是使用extends关键字
创新互联是一家专注网站建设、网络营销策划、微信小程序开发、电子商务建设、网络推广、移动互联开发、研究、服务为一体的技术型公司。公司成立十多年以来,已经为近1000家成都白乌鱼各业的企业公司提供互联网服务。现在,服务的近1000家客户与我们一路同行,见证我们的成长;未来,我们一起分享成功的喜悦。可以把类声明为final,使之不能扩张
也可以把单个方法或者字段声明为final,以确保它不能被重写,注意和Java的不同,Java中final修饰的字段意味着不可变。
5.3.2. 重写方法
在Scala中重写一个非抽象的方法必须使用override修饰符
在子类中调用超类的方法,使用super,和Java一致。
5.3.3.protected修饰的字段和方法
被protected修饰的字段或者方法,可以被其子类访问;
与Java不同的是,protected修饰的成员对于类所属的包是不可见的;
protected[this],访问权限仅限当前的对象
可以使用包修饰符改变protected修饰的成员的可见性
5.3.3. 类型检查和转换
Scala | Java | |
测试某个对象是否属于给定的类 | obj.isInstanceOf[C] | obj instanceof C |
强制类型转换 | obj.asInstanceOf[C] | (C)obj |
获取对象的类信息 | classOf[C] | C.class |
5.3.4. 超类的构造
下面代码定义了一个子类和一个调用超类构造器的主构造器
class Employ(name: String, age: Int, val Salary:Double) extends Person (name,age)
下面的代码展示类的继承,以及接口的实现等
object ClassDemo {
def main(args: Array[String]) {
val h = new Human
println(h.byScala())
}
}
//相当于Java的接口
trait Coding{
def byJava(flag : Boolean): Unit ={
if(flag)
{
println("I can code by Java")
}
else{
println("I can't code by Java")
}
}
//未被实现的方法默认为抽象方法
def byScala(): String
}
//抽象类
abstract class Animal {
def run(): Int
val name: String
}
class Human extends Animal with Coding{
val name = "abc"
//打印几次"ABC"?
val t1,t2,(a, b, c) = {
println("ABC")
(1,2,3)
}
println(a)
println(t1._1)
//在Scala中重写一个非抽象方法必须用override修饰
override def byJava(flag: Boolean): Unit = {
println("Coding by Java and Scala")
}
def byScala(): String={
"coding by Scala"
}
//在子类中重写超类的抽象方法时,不需要使用override关键字,写了也可以
def run(): Int = {
1
}
}
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
当前文章:大数据教程Scala系列之继承-创新互联
转载注明:http://pcwzsj.com/article/dgsppo.html