Scala 基础 (六):面向对象(下篇),jvm调优面试

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024b (备注Java)
img

正文

}

object Test11_Object {

def main(args: Array[String]): Unit = {

val student = Student.newStudent("alice", 12)

student.printInfo()



val student1 = Student.apply("haha", 12)



val student2 = Student("lolo", 34)

student2.printInfo()

}

}




[]( )三、特质

=================================================================



如何定义特质?



trait 特质名 {

// 代码块

}




*   Scala 语言中,采用特质 `trait`(特征)来代替接口的概念

*   多个类具有相同的特征时,就可以将这个特征提取出来,用继承的方式来复用

*   Scala 中的 trait 中即可以有抽象属性和方法,也可以有具体的属性和方法,一个类可以混入(`mixin`)多个特质。这种感觉类似于 Java 中的抽象类。



基本语法:



有父类 class extends baseClass with trait1 with trait2 … {}

没有父类 class extends trait1 with trait2 … {}




*   如果一个类在同时继承特质和父类时,应当把父类写在 `extends` 后。

*   特质中可以定义抽象和非抽象的属性和方法。



**特质叠加引发两种冲突**



> 第一种:一个类(`Sub`)混入的两个 trait(`TraitA`,`TraitB`)中具有相同的具体方法,且两个 trait 之间没有任何关系



![在这里插入图片描述](https://img-blog.csdnimg.cn/0caf06e3ae7d4e56907a40dee36fc513.png)  

如果当前父类和特质里面出现了相同的属性和方法,就会起冲突,必须在当前实现的子类(`sub`)中进行重写。



举个栗子:



class Person {

val name: String = "Person"

var age: Int = 18



def sayHi(): Unit = {

    println(s"hello from : $name")

}

}

trait Young {

// abstract and non-abstract attribute

var age: Int

val name: String = "young"



// method

def play(): Unit = {

    println(s"young people $name is playing")

}

def dating(): Unit

}

trait Knowledge {

var amount: Int = 0

def increase(): Unit = {

    amount += 1

}

}

trait Talent {

def increase(): Unit = {

    println("increase talent")

}

}

class Student extends Person with Young with Knowledge with Talent{

override val name: String = "alice"



def dating(): Unit = {

    println(s"Sutdent $name $age is dating")

}



def study(): Unit = println(s"Student $name is studying")



override def sayHi(): Unit = {

    super.sayHi()

    println(s"hello from : student $name")

}



override def increase(): Unit = {

    super.increase() 

    println(s"studnet $name knowledge increase: $amount")

}

}

object Trait {

def main(args: Array[String]): Unit = {

    val s = new Student()

    s.sayHi()

    s.increase()



    s.study()

    s.increase()



    s.play()

    s.increase()



    s.dating()

    s.increase()

}

}




> 第二种:一个类(`Sub`)混入的两个 trait(`TraitA`,`TraitB`)中具有相同的具体方法,且两个 trait 继承自相同的 trait(`TraitC`)



![在这里插入图片描述](https://img-blog.csdnimg.cn/1781221b0f624e4aa1d8cb5a51378659.png)  

Scala采用了特质叠加的策略来解决这类冲突。



举个栗子:



trait Ball {

def describe(): String = “ball”

}

trait ColorBall extends Ball {

val colorBall: String = “red”

override def describe(): String = {

 colorBall+"-----"+super.describe()

}

}

trait CategoryBall extends Ball{

val categoryBall: String = “foot”

override def describe(): String = categoryBall+“-----”+super.describe()

}

// 叠加顺序 MyFootBall -> ColorBall -> CategoryBall -> Ball

class MyFootBall extends CategoryBall with ColorBall {

override def describe(): String = “my ball is a” + super.describe()

}




*   当一个类混入多个特质的时候,scala 会对所有的特质及其父特质按照一定的顺序进行排序,而此案例中的`super.describe(`)调用的实际上是排好序后的下一个特质中的 `describe()`方法。

*   要调用某个指定的混入特质中的方法,可以增加约束:`super[]`



super[CategoryBall].describe()



**自身类型**



*   自身类型可实现依赖注入的功能。

*   一个类或者特征指定了自身类型的话,它的对象和子类对象就会拥有这个自身类型中的所有属性和方法。

*   是将一个类或者特征插入到另一个类或者特征中,属性和方法都就像直接复制插入过来一样,能直接使用。但不是继承,不能用多态。



举个栗子:



object Test16_TraitSelfType {

def main(args: Array[String]): Unit = {

val user = new RegisterUser("alice", "1212121")

user.insert()

}

}

// 用户类

class User(val name: String,val password: String){

}

trait UserDao{

// 定义自身类型

_: User =>

// 注册用户

def insert():Unit={

println (s" insert into db: = ${this.name} , ${this.password}")

}

}

// 定义注册用户

class RegisterUser(name: String,password: String) extends User(name,password) with UserDao




*   `_: SelfType =>`,其中`_`的位置是别名定义,也可以是其他,`_`指代this。插入后就可以用`this.xxx`来访问自身类型中的属性和方法了。



抽象类和特质的区别?



> 优先使用特质。一个类可以扩展多个特质,但是只能扩展一个抽象类。  

> 需要构造函数参数,使用抽象类,抽象类可以定义带参的构造器,特质只是无参的构造器。



[]( )四、扩展内容

===================================================================



**类型检查和转换**



*   `obj.isInstanceOf[T]`:判断 `obj` 是不是 `T` 类型。

*   `obj.asInstanceOf[T]`:将 `obj` 强转成 `T` 类型

*   `classOf` 获取对象的类名。结果是`class package.xxx.className`

*   获取对象的类:`obj.getClass`



**枚举类**



*   需要继承 `Enumeration`。

*   用`Value`类型定义枚举值。



// 定义枚举类

object WorkDay extends Enumeration{

val MONDAY = Value(1,“星期一”)

val TUESDAY = Value(2,“星期二”)

}

println(WorkDay.MONDAY)



**应用类**



*   继承App,包装了main方法,就不需要显式定义main方法了,可以直接执行。



object TestApp extends App{

println(“app start”

}




**定义新类型**



*   使用 type 关键字可以定义新的数据数据类型名称,本质上就是类型的一个别名



## 最后

还有Java核心知识点+全套架构师学习资料和视频+一线大厂面试宝典+面试简历模板可以领取+阿里美团网易腾讯小米爱奇艺快手哔哩哔哩面试题+Spring源码合集+Java架构实战电子书+2021年最新大厂面试题。
![在这里插入图片描述](https://img-blog.csdnimg.cn/img_convert/e089ab4753fd611741fd1c968fa33383.webp?x-oss-process=image/format,png)


**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Java)**
![img](https://img-blog.csdnimg.cn/img_convert/c05434b501f79fe7c0d3f390fe7bca56.jpeg)

**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**
{

  println("app start"

}



定义新类型

  • 使用 type 关键字可以定义新的数据数据类型名称,本质上就是类型的一个别名

最后

还有Java核心知识点+全套架构师学习资料和视频+一线大厂面试宝典+面试简历模板可以领取+阿里美团网易腾讯小米爱奇艺快手哔哩哔哩面试题+Spring源码合集+Java架构实战电子书+2021年最新大厂面试题。
[外链图片转存中…(img-a8p5fdSd-1713570875241)]

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Java)
[外链图片转存中…(img-gdEH0Yia-1713570875242)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 18
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值