5 类 



5.1 改进5.1节的Counter类,让它不要在Int.MaxValue时变成负数

  1. class Count{
  2. private var value = Int.MaxValue
  3. else value }
  4. def current = value
  5. }

5.2 编写一个BankAccount类,增加deposit和withdraw方法,和一个仅仅读的balance属性

  1. ){
  2. def deposit(){}
  3. def withdraw(){}
  4. }

5.3 编写一个Time类,增加仅仅读属性hours和minutes,和一个检查某一时刻是否早于还有一时刻的方法before(other:Time):Boolean。Time对象应该以new Time(hrs,min)方式构建。当中hrs以军用时间格式呈现(介于0和23之间)

  1. class Time(val hours:Int,val minutes:Int){
  2. def before(other:Time):Boolean={
  3. hours < other.hours || (hours == other.hours && minutes < other.minutes)
  4. }
  5. override def toString():String={
  6. hours + " : " + minutes
  7. }
  8. }

5.4 又一次实现前一个类中的Time类,将内部呈现改成午夜起的分钟数(介于0到24*60-1之间)。

不要改变公有接口。也就是说,client代码不应因你的改动而受影响

  1. class Time(val hours:Int,val minutes:Int){
  2. def before(other:Time):Boolean={
  3. hours < other.hours || (hours == other.hours && minutes < other.minutes)
  4. }
  5. override def toString():String={
  6. + minutes
  7. }
  8. }

5.5 创建一个Student类。增加可读写的JavaBeans属性name(类型为String)和id(类型为Long)。

有哪些方法被生产?(用javap查看。)你能够在Scala中调用JavaBeans的getter和setter方法吗?应该这样做吗? 

生成了name(),name_=(),id(),id_=(),setName(),getName(),setId(),getId() 编写代码例如以下

  1. import scala.reflect.BeanProperty
  2. class Student{
  3. @BeanProperty var name:String = _
  4. @BeanProperty var id:Long = _
  5. }

javap -c Student 后显演示样例如以下

  1. Compiled from "Student.scala"
  2. public class Student extends java.lang.Object implements scala.ScalaObject{
  3. public java.lang.String name();
  4. Code:
  5. :   aload_0
  6. :   getfield        #13; //Field name:Ljava/lang/String;
  7. :   areturn
  8. public void name_$eq(java.lang.String);
  9. Code:
  10. :   aload_0
  11. :   aload_1
  12. :   putfield        #13; //Field name:Ljava/lang/String;
  13. :   return
  14. public void setName(java.lang.String);
  15. Code:
  16. :   aload_0
  17. :   aload_1
  18. :   putfield        #13; //Field name:Ljava/lang/String;
  19. :   return
  20. public long id();
  21. Code:
  22. :   aload_0
  23. :   getfield        #19; //Field id:J
  24. :   lreturn
  25. public void id_$eq(long);
  26. Code:
  27. :   aload_0
  28. :   lload_1
  29. :   putfield        #19; //Field id:J
  30. :   return
  31. public void setId(long);
  32. Code:
  33. :   aload_0
  34. :   lload_1
  35. :   putfield        #19; //Field id:J
  36. :   return
  37. public long getId();
  38. Code:
  39. :   aload_0
  40. :   invokevirtual   #25; //Method id:()J
  41. :   lreturn
  42. public java.lang.String getName();
  43. Code:
  44. :   aload_0
  45. :   invokevirtual   #28; //Method name:()Ljava/lang/String;
  46. :   areturn
  47. public Student();
  48. Code:
  49. :   aload_0
  50. :   invokespecial   #34; //Method java/lang/Object."<init>":()V
  51. :   return
  52. }

5.6 在5.2节的Person类中提供一个主构造器,将负年龄转换为0

  1. class Person(var age:Int){
  2. ) 0 else age
  3. }

5.7 编写一个Person类。其主构造器接受一个字符串,该字符串包括名字,空格和姓。如new Person("Fred Smith")。

提供仅仅读属性firstName和lastName。

主构造器參数应该是var,val还是普通參数?为什么? 

必须为val。假设为var。则相应的此字符串有get和set方法。而Person中的firstName和lastName为仅仅读的,所以不能反复赋值。假设为var则会反复赋值而报错 



5.8 创建一个Car类,以仅仅读属性相应制造商,型号名称,型号年份以及一个可读写的属性用于车牌。

提供四组构造器。每一个构造器fc都要求制造商和型号为必填。

型号年份和车牌可选,假设未填,则型号年份为-1,车牌为空串。你会选择哪一个作为你的主构造器?为什么? 

这个没太明确题意。

。。

  1. ,var carLice:String = ""){
  2. }

5.9 在Java,C#或C++重做前一个练习。Scala相比之下精简多少? 

 



5.10 考虑例如以下的类 



class Employ(val name:String,var salary:Double){ 

    def this(){this("John Q. Public",0.0)} 





重写该类,使用显示的字段定义。和一个缺省主构造器。你更倾向于使用哪种形式?为什么?

  1. class Employ{
  2. val name:String = "John Q. Public"
  3. var salary:Double = 0.0
  4. }

个人更喜欢另外一种方式。简单明了。 



博客原地址:http://www.ivanpig.com/blog/?p=467

快学scala习题解答--第五章 类的更多相关文章

  1. 快学Scala习题解答—第四章 映射和元组

    4 映射和元组  4.1 设置一个映射,当中包括你想要的一些装备,以及它们的价格.然后构建还有一个映射.採用同一组键,可是价格上打9折 映射的简单操作  ,"gun"->18 ...

  2. 快学Scala习题解答—第三章 数组相关操作

    3 数组相关操作  3.1 编写一段代码.将a设置为一个n个随机整数的数组,要求随机数介于0(包括)和n(不包括)之间  random和yield的使用 import scala.math.rando ...

  3. 快学Scala习题解答—第一章 基础

    1 简介 近期对Scala比较感兴趣,买了本<快学Scala>,感觉不错.比<Programming Scala:Tackle Multi-Core Complexity on th ...

  4. 快学Scala习题解答—第十章 特质

    10 特质 10.1 java.awt.Rectangle类有两个非常实用的方法translate和grow,但可惜的是像java.awt.geom.Ellipse2D这种类没有. 在Scala中,你 ...

  5. 快学Scala 第八课 (嵌套类)

    嵌套类: class Human { class Student{ val age = 10 } } object ClassDemo { def main(args: Array[String]): ...

  6. 《C++Primer》第五版习题解答--第四章【学习笔记】

    [C++Primer]第五版习题解答--第四章[学习笔记] ps:答案是个人在学习过程中书写,可能存在错漏之处,仅作参考. 作者:cosefy Date: 2020/1/11 第四章:表达式 练习4. ...

  7. 《快学Scala》

    Robert Peng's Blog - https://mr-dai.github.io/ <快学Scala>Intro与第1章 - https://mr-dai.github.io/S ...

  8. Coursera公开课Functional Programming Principles in Scala习题解答:Week 2

    引言 OK.时间非常快又过去了一周.第一周有五一假期所以感觉时间绰绰有余,这周中间没有假期仅仅能靠晚上加周末的时间来消化,事实上还是有点紧张呢! 后来发现每堂课的视频还有相应的课件(Slide).字幕 ...

  9. 快学Scala 第十九课 (trait的abstract override使用)

    trait的abstract override使用: 当我看到abstract override介绍的时候也是一脸懵逼,因为快学scala,只介绍了因为TimestampLogger中调用的super ...

随机推荐

  1. LDAP 中 CN,OU,DC 的含意

    CN, OU, DC 都是 LDAP 连接服务器的端字符串中的区别名称(DN, Distinguished Name) LDAP连接服务器的连接字串格式为:ldap://servername/DN   ...

  2. 基于canvas的原生JS时钟效果

    概述 运用html5新增画布canvas技术,绘制时钟效果,无需引用任何插件,纯js. 详细 代码下载:http://www.demodashi.com/demo/11935.html 给大家介绍一个 ...

  3. HttpSession 和URLRewriting

    在上面使用Cookie技术存储会话信息的时候发现Cookie存储的数据有限,而且每次需要客户端浏览器携带数据,导致网络的负载过大.因此如果需要存储相对大量的数据,那么可以直接将数据存储在服务器端,这样 ...

  4. LaTex 常见错误及解决办法

    出现错误: Multirow 要用库的  导入\usepackage{multirow} ,,即可

  5. Python 常见错误及解决办法

    错误: Traceback (most recent call last): File "I:/Papers/consumer/codeandpaper/RegressionandGBDTa ...

  6. 【Arduino】超声波模块(HC-SR04)

    还好,这个模块有现成的库能够用: https://github.com/bosgood/arduino-playground/tree/master/lib/HCSR04Ultrasonic 下面仅仅 ...

  7. EF性能

    批量操作时,加上这句:Context.Configuration.AutoDetectChangesEnabled = false; 主要是取消跟踪,缩短对象添加到上下文的时间(非执行SQL的时间)

  8. hive partition 分区使用

    一.背景 1.在Hive Select查询中一般会扫描整个表内容,会消耗很多时间做没必要的工作.有时候只需要扫描表中关心的一部分数据,因此建表时引入了partition概念. 2.分区表指的是在创建表 ...

  9. C#四舍五入保留一位小数

    DateTime d1 = hrStaff.DateJoin; DateTime d2 = DateTime.Now; TimeSpan d3 = d2.Subtract(d1); ; //int i ...

  10. 跨服务器查询信息的sql

    --跨服务器查询信息的sql: select * from openrowset( 'SQLOLEDB', '192.168.1.104'; 'sa'; '123.com',[AutoMonitorD ...