1.面向对象

Scala的类与java、C++的一些比起来更简洁,速度更快

对象:使用object关键字修饰的

类:使用class关键字修饰的new Person()实例对象

new类:类的实例(对象)

1.1.单例对象

(1)scala中没有静态方法和静态字段,没有static

(2) java中,没有关键字修饰的方法,只能用new class()来修饰方法

(3)队友一个class来说,所有的方法和成员变量在市里被new出来之前都无法访问

(4)虽然在class中的定义main方法,可是并没有什么用,按时可以用object达到同样的目的

(5)用object修饰的对象是单例的,成为单例对象,静态对象

(6)单例模式涉及到一个单一的类,该类负责创建自己的对象,同时确保只有单个对象被创建,这个类提供了一种访问其唯一对象的方式,可以直接访问,不需要实例化该类的对象。注意:1.单例类只能有一个实例 2.单例类必须自己按创建自己的唯一实例 3.单例类必须给其他对象提供这一实例

代码:

object SIngeDemo {
var name="娜娜"
def eat():Unit={
println(name+"是吃货!")
}
} object test{
def main(args: Array[String]): Unit = {
SIngeDemo.eat()
}
}

1,2.伴生对象

伴生对象是一种特殊的单例对象,是一种相对概念,需要两个条件:

条件1:在同一个源文件中

条件2:对象名和类名相同

这样的单例对象,被称为这个类的伴生对象。类被称为这个实例的单例对象的伴生类。

特点:类和伴生对象之间可以相互访问私有的方法和属性

代码:

class AssociatedDemo {
private val name="笑笑"
private def eat():Unit={
println(name+"是吃货!")
println(name+"喜欢"+AssociatedDemo.action)
}
} object AssociatedDemo{
private val name="娜娜"
private val action="跑步"
def main(args: Array[String]): Unit = {
val associatedDemo = new AssociatedDemo
associatedDemo.eat()
}
}

运行结果:

1.3.apply方法

(1)我们通常会在伴生对象中定义apply方法,当遇到对象名(参数1,。。参数n)时apply方法会被调用

(2)当使用对象(参数列表)时,回去对象中找对应参数的apply方法,如果找到就执行相应的逻辑,如果找不到,就报错

注意:只能找到和参数列表相对应的apply方法

该语法的目的:更方便的完成类或实例对象的初始化方法,赋值等工作,类似于java的方法重载

代码:

//当scala中类或者对象有一个主要用途的时候,apply方法是一个湖人好的语法糖
class Test01(name:String) { } object Test01{
def apply(name: String): Test01 ={
new Test01 ( name )
}
}
//定义一个Test01类,并且在这个类中,有一个半生对象Test01,里面定义了apply方法,有了这个apply方法以后,我们在调用这个Test01类的时候,用函数方式来调用
object Client1{
def main(args: Array[String]): Unit = {
val stu=Test01("娜娜")
}
}

总结:

(1)apply方法,是object上的方法

(2)一般情况下,对象没有构造方法,不能加参数

object Test1(name:String)写法错误{

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

Test1// 这是一个对象,对象上不能有参数

Test1(a:Int) // 添加参数之后,就报错了(错误的写法)

}

}

(3)但是,如果对象(参数列表),实际上调用的是对象上的apply方法,具体会根据参数列表的个数、参数的类型去找对象上对应的apply方法,如果没有找到就会报错。返回值取决于apply的返回类型

(4)apply方法相当于java中的方法重载,可以定义多个apply方法,具体的参数类型,参数个数,以及返回值都是可以自定义。

1.4.unapply方法

unapply方法是接受一个对象,从对象中提取相应的值。主要用于模式匹配

代码:

class Money(val price:Double,val name:String) {

}

object Money{
def apply(price: Double, name: String): Money = new Money ( price, name ) def unapply(money: Money): Option[(Double, String)] = {
if (money==null){
None
}else{
Some(money.price,money.name)
}
}
} object Client2{
def main(args: Array[String]): Unit = {
val ap=Money(11.2,"书")
ap match {
case Money(num,"书")=>println(num)
case _=>println("宝宝不开心!")
} }
}

结果:

1.5.应用程序对象

scala程序都必须从一个对象的main方法开始,可以通过继承APP特质,不用写main方法(APP里面封装了main方法)

object AppDemo extends App{
println("I love you ")
}

2.类

2.1.类的定义

(1)在 scala中,类并不用生命为public

(2) scala源文件中可以包含多各类,所有的类都具有可见性

(3)var修饰的变量,这个变量对外提供了get set方法

(4)val修饰的变量,是只读属性,对外提供了get方法,没有set方法(相当于java中的final变量)

2.2.构造器

scala构造器分为两类:主构造器(只能有一个),辅助构造器(可以有多个)

(1)主构造器直接在类名后面定义,每个类都有主构造器,主构造器的参数直接放置雷鸣后面,与类交织在一起

class test(val name:String,var age:Int)

(2)如果没有定义构造器,类会有一个默认的空参构造器

(3)辅助函数的定义,使用dfs this关键字,而且必须调用主构造器,或者其他构造器

注意:主构造器会执行类定义中的所有语句

代码:

class ConstructorDemo(val name: String, var age: Int) {

  println ( "主构造器运行了。。。" )

  //辅助构造器必须定义在类中(主和辅参数不能一样)
def this(name: String, age: Int, sex: String) {
this ( name, age )
println ( "第一个辅助构造器运行了。。。。" )
} def this(name: String, age: Int, sex: String, address: String) {
this ( name, age, sex )
println ( "第二个辅助构造器运行了。。。。" )
}
} object Text {
def main(args: Array[String]): Unit = {
new ConstructorDemo ( "娜娜", )
new ConstructorDemo ( "娜娜", , "女" )
new ConstructorDemo ( "娜娜", , "女", "河南" )
}
}

总结:

1.有两类构造器,主构造器和付构造器

2.构造器定义的位置,主构造器和类交织在一起,class ConstructorDemo(val name: String, var age: Int)

3.辅助构造器是一个特殊的方法,定义在类中 def this(name: String, age: Int, sex: String, address: String)

4.辅助构造器,第一行必须是主构造器(或者其他构造器)

5.辅助构造器的参数不能和主构造器的参数完全一致(参数个数、类型、顺序)

6.可以定义空参的辅助构造器,但是主构造器参数必须进行初始化赋值

7.作用域:辅助构造器的作用于,只在方法中,主构造的作用于是类中除去成员属性和成员方法之外的所有范围(可以通过反编译查看源码)

2.3.访问权限

成员变量的访问权限

1.默认权限是public,任何地方都可以访问

2.prive作用域(用于类的内部和伴生对象中)

3.private[this],作用域在当前类中,伴生对象无效

方法的访问权限

1.通用于主构造器,辅助构造器,以及普通方法

2.默认权限是共有的

3.private作用域为类和其伴生对象

4. private [this] ,作用域为当前类中,伴生对象中无效

类的访问权限:

1.默认: 共有的

2. private private[this] 在当前包及其子包范围内有效,其他地方无效

3. private [包名] 在指定包及其子包访问内有效 其他地方无效

Scala类和对象的更多相关文章

  1. Scala实战高手****第9课:Scala类和对象彻底实战和Spark源码鉴赏

    scala类和对象 RDD中创建_sc和deps相比java更加的简洁. 在Spark的例如SparkContext.sqlSpark等全局成员在完成实例化. 在唯一实例的时候一般不会去使用伴生对象a ...

  2. Scala 类和对象

    Scala class: Scala 源文件中可以有很多类(class),这些类默认都是Public的,public是Scala的默认访问级别.在Scala中,声明一个未用priavate修饰的字段 ...

  3. Scala类与对象

    类简介 简介 类是对象的蓝图.一旦你定义了类,就可以用关键字new根据类的蓝图创建对象.在类的定义里,可以放置字段和方法,这些被笼统地称为成员.对于字段,不管是val还是var定义的,都是指向对象的变 ...

  4. Spark记录-Scala类和对象

    本章将介绍如何在Scala编程中使用类和对象.类是对象的蓝图(或叫模板).定义一个类后,可以使用关键字new来创建一个类的对象. 通过对象可以使用定义的类的所有功能. 下面的图通过一个包含成员变量(n ...

  5. Scala类和对象(二)

    1. 类和属性 1.1 如何控制构造函数字段的可见性 在Scala中: 如果一个字段被声明为var, Scala会为该字段生成getter和setter方法. 如果字段是val, Scala只生成ge ...

  6. scala 类,伴生对象

    1.属性的定义 编写一个PersonS类,并在其中定义一些属性,通过PersonS.scala 编译后的情况查看,可以知道不同修饰符修饰的属性分别会生成什么方法(set,get) package co ...

  7. Spark记录-Scala类与对象小例子

    //基类-Person class Person(val na: String, val ag: Int) { //属性 var name: String = na var age: Int = ag ...

  8. Scala:类,对象和特征(接口)

    http://blog.csdn.net/pipisorry/article/details/52902609 Scala类和对象 类是对象的抽象,而对象是类的具体实例.类是抽象的,不占用内存,而对象 ...

  9. Scala 编程---类和对象

    类是对象的蓝图.一旦你定义了类,你就可以用关键字new从类的蓝图里创建对象.比方说,如果给出了类的定义: class ChecksumAccumulator { // class definition ...

随机推荐

  1. git 命令解析

    git 补丁 Git 提供了两种补丁方案:   (1)用 git diff 生成的UNIX标准补丁.diff文件:.diff文件只是记录文件改变的内容,不带有commit记录信息,多个commit可以 ...

  2. JDK12的安装搭建

    JDK12的安装搭建 一.JDK下载 ​ 1.JDK官网下载地址:https://www.oracle.com/technetwork/java/javase/downloads/jdk12-down ...

  3. MINIUI grid学习笔记

    grid 控件a.事件的绑定和移除         grid.on("rowclick", fn); //绑定事件 (这个的话类似jquery的绑定事件)         grid ...

  4. [USACO12FEB]牛券Cow Coupons(堆,贪心)

    [USACO12FEB]牛券Cow Coupons(堆,贪心) 题目描述 Farmer John needs new cows! There are N cows for sale (1 <= ...

  5. 洛谷P1412 经营与开发题解

    题目链接QWQ这里就不阐述了: 题解部分: 从题面上来看,这是个dp(递推)的题目. 但是dp要满足无后效性,但这个题为了取最值,得考虑从当前开始一直持续到结束的p的影响. 这让我们怎么满足无后效性? ...

  6. Java基本的程序结构设计 基本类型的输入输出

    读取输入: java.util.Scanner 一个可以使用正则表达式来分析基本类型和字符串的简单文本扫描器. 了解: Scanner 使用分隔符模式将其输入分解为标记,默认情况下该分隔符模式与空白匹 ...

  7. 有关pip报错的问题

    错误消息:“Fatal error in launcher: Unable to create process using '"' 解决办法: python3解决方案:python3 -m ...

  8. vue-cli3.0的配置

    转自 https://www.cnblogs.com/sangzs/p/9543242.html module.exports = { // 基本路径 baseUrl: '/', // 输出文件目录 ...

  9. keras学习笔记-bili莫烦

    一.keras的backend设置 有两种方式: 1.修改JSON配置文件 修改~/.keras/keras.json文件内容为: { "iamge_dim_ordering":& ...

  10. Linux 查看内存(free)、释放内存(基本操作)

    原文链接:http://blog.51cto.com/11495268/2384147 1.简介 1.1 介绍 很多时候,服务器 负载 很高(执行操作 很慢),很多 原因 造成 这种 现象(内存不足 ...