1、基本语法:

构造器分为主构造器和辅助构造器

class 类名(形参列表) {  // 主构造器

// 类体

def  this(形参列表) {  // 辅助构造器

}

def  this(形参列表) {  //辅助构造器可以有多个...

}

}

//1. 辅助构造器 函数的名称this, 可以有多个,编译器通过不同参数来区分

2、主构造器

class Person(val age:Int,var name:String, sex:Int, score1:Int) {
  var score = score1
  print("主构造器")
} object Person{
  def main(args: Array[String]): Unit = {
    new Person(3,"zhangsan",1,88)
  }
}

执行结果:

反编译:

public class
Person

{

private final int age;

private int score;

public int age() //get

{

return this.age;

}

public String name() //get

{

return this.name;

}

public void name_$eq(String x$1) //set

{

this.name = x$1;

}

public int score() //get

{

return this.score;

}

public void score_$eq(int x$1) //set

{

this.score = x$1;

}

public Person(int age, String name, int sex, int score1)

{

this.score = score1;

Predef..MODULE$.print("Ö÷¹¹ÔìÆ÷");

}

public static void main(String[] paramArrayOfString)

{

Person..MODULE$.main(paramArrayOfString);

}

}

从上面的代码和结果可以得:

1、主构造器的声明直接放在类名后面

2、主构造器会执行所有的代码,方法定义除外

3、如果主构造无参数,后面的小括号可以省略(简单,不作证明)

4、如果想让主构造器私有化,则可以在(参数)前面添加private关键字

5、从上面代码中我们在Person类中有三个变量

被val修饰,则为只读属性,会生成一个相当于get的方法(反编译看)

被var修饰,则为读写属性,会生成一个相当于get和set的方法

没有被修饰,则是一个局部变量,则不会生成任何方法

其中的sex属性没有生产任何的方法,是局部变量,而score是里面定义的变量,朱构造器也会执行,score1是局部变量,也不会生成任何的相关方法。

3、辅助构造器

class Person(val age:Int,var name:String, sex:Int, score1:Int) {
  var score = score1
  println("主构造器")   def this(age:Int, name:String){
    //辅助构造器必须显示的调用主构造器,可以通过调用其他辅助构造器间接调用
    this(age,name,21,99)
    print("辅助构造器")
  }
} object Person{
  def main(args: Array[String]): Unit = {
    new Person(3,"zhangsan")
  }
}

运行结果:

辅助构造器的名称为this,多个辅助构造器通过不同的参数列表进行区分,也就是重载

4、Bean属性

将scala字段添加@BeanProperty就会生成同java类似的get和set方法

import scala.beans.BeanProperty

  class Person( val name:String, @BeanProperty var age:Int) {
  print("主构造器")
} object Person{
  def main(args: Array[String]): Unit = {
    new Person("zhangsan",7)
  }
}

反编译结果

public class Person

{

private final String name;

public String name()

{

return this.name;

}

public int age()

{

return this.age;

}

public void age_$eq(int x$1)

{

this.age = x$1;

}

public void setAge(int x$1)  //setAge

{

this.age = x$1;

}

public int getAge() //getAge

{

return age();

}

public Person(String name, int age)

{

Predef..MODULE$.print("主构造器");

}

public static void main(String[] paramArrayOfString)

{

Person..MODULE$.main(paramArrayOfString);

}

}

从上面的代码,可以得出生成了get和set方法,如果是val修饰,则只会有get方法

scala之构造器详解的更多相关文章

  1. Scala进阶之路-Scala函数篇详解

    Scala进阶之路-Scala函数篇详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.传值调用和传名调用 /* @author :yinzhengjie Blog:http: ...

  2. windows scala helloworld例子详解

    [学习笔记] windows scala helloworld例子详解: 在操作系统中,我们的Test3.scala会生成Test3.class,然后class文件被虚拟机加载并执行, 这一点和jav ...

  3. Scala面向对象—类详解

    package com.zzy import scala.beans.BeanProperty class Aclass { @BeanProperty//生成get和set方法对于其他框架里对标准的 ...

  4. 关于scala环境配置详解

    首先从官网下载适合自身电脑配置的scala安装包.scala下载官网网址:http://www.scala-lang.org/download/ 同时scala还有自己集成好的IDE,例如eclips ...

  5. linkin大话面向对象--构造器详解

       对象的产生格式:类名称  对象名 = new  类名称(); 因为有(),所以是方法,实际上它就是构造方法,并且是非私有的构造方法.如:CellPhone cp = new CellPhone( ...

  6. scala 隐式详解(implicit关键字)

    掌握implicit的用法是阅读spark源码的基础,也是学习scala其它的开源框架的关键,implicit 可分为: 隐式参数 隐式转换类型 隐式调用函数 1.隐式参数 当我们在定义方法时,可以把 ...

  7. Scala集合类型详解

    Scala集合 Scala提供了一套很好的集合实现,提供了一些集合类型的抽象. Scala 集合分为可变的和不可变的集合. 可变集合可以在适当的地方被更新或扩展.这意味着你可以修改,添加,移除一个集合 ...

  8. Scala面向对象—类详解2(继承相关)

    1.单例类 package com.zzzy class AAA {//单例 /*//java 思路--私有化构造方法,提供公开的getAAA 行不通 private def this(){ this ...

  9. Java面向对象系列(5)- 构造器详解

    构造器: 和类名相同 没有返回值 作用: new本质在调用构造器 初始化对象的值 注意点: 定义了有参构造之后,如果想要使用有参构造,必须显示的定义一个无参构造 IDEA快捷键: Alt + Inse ...

随机推荐

  1. Greenplum客户端访问控制

    1. 问题描述 Greenplum默认是对客户端不开放的,即客户端要访问Greenplum数据库,需要首先开通权限. 2. 解决方案: 2.1.安装greenplum-cc-web控制台. ​ Gp的 ...

  2. k8s学习 - 概念 - ReplicationController

    k8s学习 - 概念 - ReplicationController 我们有了 pod,那么就需要对 pod 进行控制,就是同一个服务的 podv我需要启动几个?如果需要扩容了,怎么办?这里就有个控制 ...

  3. Logstash : 从 SQL Server 读取数据

    有些既存的项目把一部分日志信息写入到数据库中了,或者是由于其它的原因我们希望把关系型数据库中的信息读取到 elasticsearch 中.这种情况可以使用 logstash 的 jdbc input ...

  4. spark 源码分析之十五 -- Spark内存管理剖析

    本篇文章主要剖析Spark的内存管理体系. 在上篇文章 spark 源码分析之十四 -- broadcast 是如何实现的?中对存储相关的内容没有做过多的剖析,下面计划先剖析Spark的内存机制,进而 ...

  5. solidity智能合约中tx.origin的正确使用场景

    简介 tx.origin是Solidity的一个全局变量,它遍历整个调用栈并返回最初发送调用(或事务)的帐户的地址.在智能合约中使用此变量进行身份验证会使合约容易受到类似网络钓鱼的攻击. 但针对tx. ...

  6. 【动态规划例题-数塔问题】-C++

    描述 观察下面的数字金字塔.写一个程序查找从最高点到底部任意处结束的路径,使路径经过数字的和最大.每一步可以 从当前点走到左下方的点也可以到达右下方的点. 在上面的样例中,从13到8到26到15到24 ...

  7. 【CYH-02】NOIp考砸后虐题赛:坐标:题解

    代码: 这道题也并不难,用排序+简单动规即可.因为@Kevin_Wa 大佬放的是c++,所以我来一发Pascal. var min,max,i,a1,b1,c1,d1,n:longint; a,b,c ...

  8. 洛谷P1690 贪婪的Copy 题解

    题目:https://www.luogu.org/problemnew/show/P1690 分析: 这道题就是一道最短路的题目,因为看到数据范围: n≤100n\leq100n≤100 所以考虑使用 ...

  9. Docker笔记(六):容器管理

    原文地址:http://blog.jboost.cn/2019/07/21/docker-6.html 容器是Docker中的另一核心概念,在Docker中,应用的运行都是在容器内进行的,容器则基于镜 ...

  10. Spark学习之RDD

    RDD概述 什么是RDD RDD(Resilient Distributed Dataset)叫做弹性分布式数据集,是Spark中最基本的数据抽象,它代表一个不可变.可分区.里面的元素可并行计算的集合 ...