先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7
深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年最新Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Java开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
如果你需要这些资料,可以添加V获取:vip1024b (备注Java)
正文
}
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行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!