定义类


// 定义类,包含field以及method
class HelloWorld {
private var name = "Leo"
def sayHello() { println("Hello" + name)}
def getName = name
}
defined class HelloWorld
// 创建类对象,并调用其方法
scala> val helloworld = new HelloWorld
helloworld: HelloWorld = HelloWorld@4f49f6af
scala> helloworld.sayHello() // 也可以不加括号
HelloLeo
scala> print(helloworld.getName) // 不能加括号,因为定义方法的时候没有加括号
Leo

封装(setter与getter)

  • 定义不加参数的var filed,Scala会将该字段定义为private,并提供public的getter和setter方法
  • 如果使用private修饰field, 则生成的getter和setter也是private的
  • 如果定义val field, 则只会生成getter方法
  • 如果使用private[this]修饰field,则不会生成getter和setter方法 
    总结:Scala提供的四种修饰符:var、val、private、private[this]

class Student {
var name = "sparks"
}
defined class Student
scala> val spark = new Student
spark: Student = Student@6337c201
// 调用自动生成的setter和getter方法
scala> print(spark.name)
sparks
scala> spark.name = "hahah"
spark.name: String = hahah

如果希望能够自己对getter和setter进行控制,则可以自定义getter与setter方法,使用field和fild_=的方式。


class Student{
private var myName = "Sparks"
def name = "Your name is" + myName
def name_=(newName: String) {
myName = newName
}
}
val spark = new Student
print(spark.name)
spark.name = "Leo"

注意:自义定setter方法一定要注意scala的语法限制,签名、_=参数间不能有空格。

private[this]的详解

如果字段是private修饰的,那么代码这个字段时私有的,在类的方法中,可以直接访问类的其他对象的private field。 
例如:


class Student {
private var myAge = 0
def age_=(newValue: Int){
if(newValue>0) { myAge = newValue}
else print("illegal age!")
}
def age = myAge
def older(s: Student) = {
myAge > s.myAge // 调用另一个对象s的私有字段并不报错
}
}

  
但是如果是用private[this]修饰,那么意味着该对象私有字段只有本对象内才可以访问,上面的代码就会报错


<console>:16: error: value myAge is not a member of Student
myAge > s.myAge // 调用另一个对象s的私有字段并不报错

Java风格的getter和setter方法

如果要让scala自动生成java风格的getter和setter方法,只要给field添加@BeanProperty注解即可。 
此时会生成4个方法,name: String、 name_=(newValue: String): Unit、 getName(): String、 setName(newValue: String): Unit


// 定义类
import scala.reflect.BeanProperty
class Student{
@BeanProperty var name: String = _
}
defined class Student
// 测试类
scala> val s = new Student
s: Student = Student@5f303ecd
scala> s.setName("leo")
scala> s.getName()
res9: String = leo
scala> s.name
res10: String = leo
scala> s.name = "spark"
s.name: String = spark
scala> s.getName()
res11: String = spark
// 定义Java风格类的第二种方式
class Student(@BeanProperty var name: String)

构造函数

主构造函数

在Scala中,主constructor是与类名放在一起的,而且类中没有定义在任何方法或者是代码块之中的代码,就是主constructor的代码,这点很新颖,但感觉没有java清晰。


class Student(val name: String, val age: Int) {
println("your name is " + name + ", your age is " + age)
}
defined class Student
scala> val s = new Student("spark", 30)
your name is spark, your age is 30
s: Student = Student@43b40233
// 还可以使用默认参数
class Student(val name: String = "leo", val age: Int = 30) {
println("your name is " + name + ", your age is " + age)
}
defined class Student
// 这样新建对象时就不用传递参数了
scala> val s = new Student
your name is leo, your age is 30

注意:如果主constucutor传入的参数什么修饰都没有,比如name: String, 那么如果类内部的方法使用到了,则会生命为private[this] name; 否则没有该field,就只能被constructor代码使用而已。

辅助构造函数(this)

Scala中,可以给类定义多个辅助constructor,类似于java中的构造函数重载 
辅助constructor之间可以互相调用,而且必须第一行调用主constructor


// 定义类
class Student{
private var name = ""
private var age = 0
def this(name: String){
this() // 必须调用主构造函数
this.name = name
}
def this(name: String, age:Int) {
this(name) // 必须调用主构造函数
this.age = age
}
}
defined class Student
// 测试类
scala> val s1 = new Student
s1: Student = Student@387bf2d9
scala> val s2 = new Student("sparks")
s2: Student = Student@5e746d37
scala> val s3 = new Student("spark", 23)
s3: Student = Student@5524b72f

类部类

在Scala中,同样可以在类中定义内部类;但是与java不同的是,每个外部类对象的内部类,都是不同的类


// 定义内部类
import scala.collection.mutable.ArrayBuffer
class Class{
class Student(val name: String){}
val students = new ArrayBuffer[Student]
def getNewStudent(name: String) = {
new Student(name)
}
}
defined class Class
scala> val c1 = new Class
scala> val s1 = c1.getNewStudent("spark")
scala> c1.students += s1
scala> val c2 = new Class
scala> val s2 = c2.getNewStudent("leo")
scala> c1.students += s2
// 出错,因为每个外部类对象的内部类都是不同的类
<console>:15: error: type mismatch;
found : c2.Student
required: c1.Student
c1.students += s2
^

Scala入门系列(五):面向对象之类的更多相关文章

  1. C语言高速入门系列(五)

    C语言高速入门系列(五) C语言指针初涉                                           ------转载请注明出处:coder-pig 本节引言: 上一节我们对C ...

  2. Scala入门系列(九):函数式编程

    引言 Scala是一门既面向对象,又面向过程的语言,Scala的函数式编程,就是Scala面向过程最好的佐证.也真是因此让Scala具备了Java所不具备的更强大的功能和特性. 而之所以Scala一直 ...

  3. Go语言入门系列(五)之指针和结构体的使用

    Go语言入门系列前面的文章: Go语言入门系列(二)之基础语法总结 Go语言入门系列(三)之数组和切片 Go语言入门系列(四)之map的使用 1. 指针 如果你使用过C或C++,那你肯定对指针这个概念 ...

  4. Scala入门系列(七):面向对象之继承

    extends 与Java一样,也是使用extends关键字,使用继承可以有效复用代码 class Person { private var name = "leo" def ge ...

  5. Scala入门系列(八):面向对象之trait

    基础知识 1 将trait作为接口使用 此时Trait就与Java中的接口非常类似,不过注意,在Scala中无论继承还是trait,统一都是extends关键字. Scala跟Java 8前一样不支持 ...

  6. Scala入门系列(六):面向对象之object

    object object相当于class的单个实例,类似于Java中的static,通常在里面放一些静态的field和method.   第一次调用object中的方法时,会执行object的con ...

  7. spring cloud 入门系列五:使用Feign 实现声明式服务调用

    一.Spring Cloud Feign概念引入通过前面的随笔,我们了解如何通过Spring Cloud ribbon进行负责均衡,如何通过Spring Cloud Hystrix进行服务断路保护,两 ...

  8. Scala入门系列(一):基础语法

    Scala基础语法 Scala与JAVA的关系 Scala是基于Java虚拟机,也就是JVM的一门编程语言,所有Scala的代码都需要经过编译为字节码,然后交由Java虚拟机来运行. 所以Scala和 ...

  9. Scala入门系列(四):Map & Tuple

    Map 创建Map // 创建一个不可变的Map scala> val ages = Map("Leo" -> 30, "Sparks" -> ...

随机推荐

  1. 2017年最受欢迎的UI框架

    前端领域最近几年发展的特别迅速,可以说是百家争鸣.在底层的前端框架领域中,最早是jquery称霸互联网,近两年MVVM类型的框架慢慢成为主流,Vue.React和Angular三大框架并驾齐驱.可以说 ...

  2. LeetCode 531. Longly Pixel I (孤独的像素之一) $

    Given a picture consisting of black and white pixels, find the number of black lonely pixels. The pi ...

  3. SAP开发快捷键

    F1 帮助     F2 回车确认(在某些地方可用,比如ABAP)     F3 返回     F4 选择输入项     F5 新增     F6 复制为...     F7 全选     F8 选择 ...

  4. hadoop2.6环境中部署hive1.2.2的错误

    1.hive配置遇到的问题( Relative path in absolute URI: ${system:java.io.tmpdir%7D/$%7Bsystem:user.name%7D) 解决 ...

  5. Leetcode题解(22)

    66. Plus One 题目 这题很简单,直接代码: class Solution { public: vector<int> plusOne(vector<int> &am ...

  6. code force 424 A - Office Keys

    There are n people and k keys on a straight line. Every person wants to get to the office which is l ...

  7. Python 判断是否为质数或素数

    一个大于1的自然数,除了1和它本身外,不能被其他自然数(质数)整除(2, 3, 5, 7等),换句话说就是该数除了1和它本身以外不再有其他的因数. 首先我们来第一个传统的判断思路: def handl ...

  8. Java IO编程全解(三)——伪异步IO编程

    转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/7723174.html 前面讲到:Java IO编程全解(二)--传统的BIO编程 为了解决同步阻塞I/O面临 ...

  9. onload、DOMContentLoaded与性能问题

    onload.DOMContentLoaded与性能问题 onload事件 DomContentLoaded   1.onload事件 onload事件一般在所有的文档内容加载完成后触发,如果网页中图 ...

  10. css媒体查询:响应式网站

    css媒体查询:响应式网站 媒体查询 包含了一个媒体类型和至少一个使用如宽度.高度和颜色等媒体属性来限制样式表范围的表达式.CSS3加入的媒体查询使得无需修改内容便可以使样式应用于某些特定的设备范围. ...