当前位置: 首页 > news >正文

包头正规旅游网站开发哪家好网站开发的公司电话

包头正规旅游网站开发哪家好,网站开发的公司电话,网站怎么被百度收录,秦皇岛企业建设网站1. 类的继承 1.1 Scala中的继承结构 Scala 中继承关系如下图#xff1a; Any 是整个继承关系的根节点#xff1b; AnyRef 包含 Scala Classes 和 Java Classes#xff0c;等价于 Java 中的 java.lang.Object#xff1b; AnyVal 是所有值类型的一个标记#xff1b; Nul…1. 类的继承 1.1 Scala中的继承结构 Scala 中继承关系如下图  Any 是整个继承关系的根节点  AnyRef 包含 Scala Classes 和 Java Classes等价于 Java 中的 java.lang.Object  AnyVal 是所有值类型的一个标记  Null 是所有引用类型的子类型唯一实例是 null可以将 null 赋值给除了值类型外的所有类型的变量;  Nothing 是所有类型的子类型。 1.2 extends  override Scala 的集成机制和 Java 有很多相似之处比如都使用 extends 关键字表示继承都使用 override 关键字表示重写父类的方法或成员变量。示例如下 //父类 class Person {var name  // 1.不加任何修饰词,默认为 public,能被子类和外部访问var age  0// 2.使用 protected 修饰的变量能子类访问但是不能被外部访问protected var birthday  // 3.使用 private 修饰的变量不能被子类和外部访问private var sex    def setSex(sex: String): Unit  {this.sex  sex}// 4.重写父类的方法建议使用 override 关键字修饰override def toString: String  name  :  age  :  birthday  :  sex } 使用 extends 关键字实现继承 // 1.使用 extends 关键字实现继承 class Employee extends Person {override def toString: String  Employee~ super.toString// 2.使用 public 或 protected 关键字修饰的变量能被子类访问def setBirthday(date: String): Unit  {birthday  date} } 测试继承 object ScalaApp extends App {val employee  new Employee  employee.name  shangjackemployee.age  20employee.setBirthday(2019-03-05)employee.setSex(男)println(employee) }// 输出 Employee~shangjack:20:2019-03-05:男1.3 调用超类构造器 在 Scala 的类中每个辅助构造器都必须首先调用其他构造器或主构造器这样就导致了子类的辅助构造器永远无法直接调用超类的构造器只有主构造器才能调用超类的构造器。所以想要调用超类的构造器代码示例如下 class Employee(name:String,age:Int,salary:Double) extends Person(name:String,age:Int) {..... } 1.4 类型检查和转换 想要实现类检查可以使用 isInstanceOf判断一个实例是否来源于某个类或者其子类如果是则可以使用 asInstanceOf 进行强制类型转换。 object ScalaApp extends App {val employee  new Employeeval person  new Person// 1. 判断一个实例是否来源于某个类或者其子类 输出 true println(employee.isInstanceOf[Person])println(person.isInstanceOf[Person])// 2. 强制类型转换var p: Person  employee.asInstanceOf[Person]// 3. 判断一个实例是否来源于某个类 (而不是其子类)println(employee.getClass  classOf[Employee]) } 1.5 构造顺序和提前定义 1.5.1 构造顺序 在 Scala 中还有一个需要注意的问题如果你在子类中重写父类的 val 变量并且超类的构造器中使用了该变量那么可能会产生不可预期的错误。下面给出一个示例 // 父类 class Person {println(父类的默认构造器)val range: Int  10val array: Array[Int]  new Array[Int](range) }//子类 class Employee extends Person {println(子类的默认构造器)override val range  2 }//测试 object ScalaApp extends App {val employee  new Employeeprintln(employee.array.mkString((, ,, ))) } 这里初始化 array 用到了变量 range这里你会发现实际上 array 既不会被初始化 Array(10)也不会被初始化为 Array(2)实际的输出应该如下 父类的默认构造器 子类的默认构造器 ()可以看到 array 被初始化为 Array(0)主要原因在于父类构造器的执行顺序先于子类构造器这里给出实际的执行步骤 1. 父类的构造器被调用执行 new Array[Int](range) 语句; 2. 这里想要得到 range 的值会去调用子类 range() 方法因为 override val 重写变量的同时也重写了其 get 方法 3. 调用子类的 range() 方法自然也是返回子类的 range 值但是由于子类的构造器还没有执行这也就意味着对 range 赋值的 range  2 语句还没有被执行所以自然返回 range 的默认值也就是 0。 这里可能比较疑惑的是为什么 val range  2 没有被执行却能使用 range 变量这里因为在虚拟机层面是先对成员变量先分配存储空间并赋给默认值之后才赋予给定的值。想要证明这一点其实也比较简单代码如下: class Person {// val range: Int  10 正常代码 array 为 Array(10)val array: Array[Int]  new Array[Int](range)val range: Int  10 //如果把变量的声明放在使用之后此时数据 array 为 array(0) }object Person {def main(args: Array[String]): Unit  {val person  new Personprintln(person.array.mkString((, ,, )))} } 1.5.2 提前定义 想要解决上面的问题有以下几种方法 (1) . 将变量用 final 修饰代表不允许被子类重写即 final val range: Int  10  (2) . 将变量使用 lazy 修饰代表懒加载即只有当你实际使用到 array 时候才去进行初始化 lazy val array: Array[Int]  new Array[Int](range) (3) . 采用提前定义代码如下代表 range 的定义优先于超类构造器。 class Employee extends {//这里不能定义其他方法override val range  2 } with Person {// 定义其他变量或者方法def pr(): Unit  {println(Employee)} }但是这种语法也有其限制你只能在上面代码块中重写已有的变量而不能定义新的变量和方法定义新的变量和方法只能写在下面代码块中。 类的继承和下文特质 (trait) 的继承都存在这个问题也同样可以通过提前定义来解决。虽然如此但还是建议合理设计以规避该类问题。 2. 抽象类 Scala 中允许使用 abstract 定义抽象类并且通过 extends 关键字继承它。 定义抽象类 abstract class Person {// 1.定义字段var name: Stringval age: Int// 2.定义抽象方法def geDetail: String// 3. scala 的抽象类允许定义具体方法def print(): Unit  {println(抽象类中的默认方法)} } 继承抽象类 class Employee extends Person {// 覆盖抽象类中变量override var name: String  employeeoverride val age: Int  12// 覆盖抽象方法def geDetail: String  name  :  age } 3. 特质 3.1 trait  with Scala 中没有 interface 这个关键字想要实现类似的功能可以使用特质 (trait)。trait 等价于 Java 8 中的接口因为 trait 中既能定义抽象方法也能定义具体方法这和 Java 8 中的接口是类似的。 // 1.特质使用 trait 关键字修饰 trait Logger {// 2.定义抽象方法def log(msg: String)// 3.定义具体方法def logInfo(msg: String): Unit  {println(INFO:  msg)} }想要使用特质需要使用 extends 关键字而不是 implements 关键字如果想要添加多个特质可以使用 with 关键字。 // 1.使用 extends 关键字,而不是 implements,如果想要添加多个特质可以使用 with 关键字 class ConsoleLogger extends Logger with Serializable with Cloneable {// 2. 实现特质中的抽象方法def log(msg: String): Unit  {println(CONSOLE:  msg)} }3.2 特质中的字段 和方法一样特质中的字段可以是抽象的也可以是具体的 如果是抽象字段则混入特质的类需要重写覆盖该字段 如果是具体字段则混入特质的类获得该字段但是并非是通过继承关系得到而是在编译时候简单将该字段加入到子类。 trait Logger {// 抽象字段var LogLevel:String// 具体字段var LogType  FILE }// 覆盖抽象字段 class InfoLogger extends Logger {// 覆盖抽象字段override var LogLevel: String  INFO }3.3 带有特质的对象 Scala 支持在类定义的时混入  父类 trait而在类实例化为具体对象的时候指明其实际使用的  子类 trait。示例如下 trait Logger // 父类 trait Logger {// 定义空方法 日志打印def log(msg: String) {} }// trait ErrorLogger// 错误日志打印继承自 Logger trait ErrorLogger extends Logger {// 覆盖空方法override def log(msg: String): Unit  {println(Error:  msg)} }// trait InfoLogger// 通知日志打印继承自 Logger trait InfoLogger extends Logger {// 覆盖空方法override def log(msg: String): Unit  {println(INFO:  msg)} }具体的使用类 // 混入 trait Logger class Person extends Logger {// 调用定义的抽象方法def printDetail(detail: String): Unit  {log(detail)} }这里通过 main 方法来测试 object ScalaApp extends App {// 使用 with 指明需要具体使用的 trait  val person01  new Person with InfoLoggerval person02  new Person with ErrorLoggerval person03  new  Person with InfoLogger with ErrorLoggerperson01.log(scala) //输出 INFO:scalaperson02.log(scala) //输出 Error:scalaperson03.log(scala) //输出 Error:scala} 这里前面两个输出比较明显因为只指明了一个具体的 trait这里需要说明的是第三个输出因为 trait 的调用是由右到左开始生效的**所以这里打印出 Error:scala。 3.4 特质构造顺序 trait 有默认的无参构造器但是不支持有参构造器。一个类混入多个特质后初始化顺序应该如下 // 示例 class Employee extends Person with InfoLogger with ErrorLogger {...}1. 超类首先被构造即 Person 的构造器首先被执行 2. 特质的构造器在超类构造器之前在类构造器之后特质由左到右被构造每个特质中父特质首先被构造 Logger 构造器执行Logger 是 InfoLogger 的父类 InfoLogger 构造器执行 ErrorLogger 构造器执行; 3. 所有超类和特质构造完毕子类才会被构造。
http://www.dnsts.com.cn/news/95882.html

相关文章:

  • 企业网站如何推广东莞东城社保局电话
  • 做a 免费网站wordpress仿砍柴网
  • 给女朋友做的网站视频网站开发报告
  • 网站开发团队如何接活邯郸移动网站建设
  • 门户网站建设推荐网站移动端适配怎么做
  • 鄱阳网站建设企业网站建设公司郑州
  • 深圳网站设计公司在什么地方百度关键词点击工具
  • 找做外墙油漆网站论坛企业推广
  • 网站制作教程pptwordpress搜索功能优化
  • 做电影网站怎样赚钱吗wordpress中目录如何表示
  • 高校网站建设的时效性上海教育网站建设
  • 哪个网站找做软件下载小城镇建设期刊网站
  • 销售网站建设常遇到的问题购买的网站怎么看网站空间大小
  • 六安seo网站推广报价商城网站案例
  • 信息化建设好的企业网站有哪些公司注册上海
  • 泰州做兼职的网站引导交互 网站
  • 一起做网店网站打不开深圳市文刀网站建设
  • 网站开发前端和后端用什么语言有没有做家纺类的网站
  • 中小企业还需要网站吗广告公司简介宣传册
  • 广安 网站建设休闲吧网站建设
  • 无锡网站怎么做wordpress搜索所有类
  • 做酒店网站wordpress网站地图插件
  • 个人怎么开网站马可波罗网介绍
  • 网站怎样做wap端济宁正德网站建设
  • 苏州自助建站模板wordpress外贸建站教程
  • 做网站充值微信必须是企业中国万网是做什么的
  • php网站开发有前景吗关键词搜索引擎工具
  • python做网站怎么样求一个免费的
  • 建站快车加盟wordpress右边小工具栏
  • 学校微网站模板wordpress安装模版500