快学scala第十章习题答案 联系客服

发布时间 : 星期三 文章快学scala第十章习题答案更新完毕开始阅读5f20077c6bd97f192279e994

11 特质

11.1 java.awt.Rectangle类有两个很有用的方法translate和grow,但可惜的是像

java.awt.geom.Ellipse2D这样的类没有。在Scala中,你可以解决掉这个问题。定义一个RenctangleLike特质,加入具体的translate和grow方法。提供任何你需要用来实现的抽象方法,以便你可以像如下代码这样混入该特质:

val egg = new java.awt.geom.Ellipse2D.Double(5,10,20,30) with RectangleLike

egg.translate(10,-10)

egg.grow(10,20)

使用自身类型使得trait可以操作x,y

import java.awt.geom.Ellipse2D

trait RectangleLike{

this:Ellipse2D.Double=>

def translate(x:Double,y:Double){

this.x = x

this.y = y

}

def grow(x:Double,y:Double){

this.x += x

this.y += y

}

}

object Test extends App{

val egg = new Ellipse2D.Double(5,10,20,30) with RectangleLike

println(\ + egg.getX + \ + egg.getY)

egg.translate(10,-10)

println(\ + egg.getX + \ + egg.getY)

egg.grow(10,20)

println(\ + egg.getX + \ + egg.getY)

}

11.2 通过把scala.math.Ordered[Point]混入java.awt.Point的方式,定义OrderedPoint类。按辞典编辑方式排序,也就是说,如果x

import java.awt.Point

class OrderedPoint extends Point with Ordered[Point]{

def compare(that: Point): Int = if (this.x <= that.x && this.y < that.y) -1

else if(this.x == that.x && this.y == that.y) 0

else 1

}

11.3 查看BitSet类,将它的所有超类和特质绘制成一张图。忽略类型参数([…]中的所有内容)。然后给出该特质的线性化规格说明

这个略

11.4 提供一个CryptoLogger类,将日志消息以凯撒密码加密。缺省情况下密匙为3,不过使用者也可以重写它。提供缺省密匙和-3作为密匙是的使用示例

trait Logger{

def log(str:String,key:Int = 3):String

}

class CryptoLogger extends Logger{

def log(str: String, key:Int): String = {

for ( i <- str) yield if (key >= 0) (97 + ((i - 97 + key)&)).toChar else (97 + ((i - 97 + 26 + key)&)).toChar

}

}

object Test extends App{

val plain = \;

println(\明文为:\ + plain);

println(\加密后为:\ + new CryptoLogger().log(plain));

println(\加密后为:\ + new CryptoLogger().log(plain,-3));

}

11.5 JavaBean规范里有一种提法叫做属性变更监听器(property change listener),这是bean用来通知其属性变更的标准方式。PropertyChangeSupport类对于任何想要支持属性变更通知其属性变更监听器的bean而言是个便捷的超类。但可惜已有其他超类的类—比如

JComponent—必须重新实现相应的方法。将PropertyChangeSupport重新实现为一个特质,然后将它混入到java.awt.Point类中

import java.awt.Point

import java.beans.PropertyChangeSupport

trait PropertyChange extends PropertyChangeSupport

val p = new Point() with PropertyChange

11.6 在Java AWT类库中,我们有一个Container类,一个可以用于各种组件的Component子类。举例来说,Button是一个Component,但Panel是Container。这是一个运转中的组合模式。Swing有JComponent和JContainer,但如果你仔细看的话,你会发现一些奇怪的细节。尽管把其他组件添加到比如JButton中毫无意义,JComponent依然扩展自Container。Swing的设计者们理想情况下应该会更倾向于图10-4中的设计。但在Java中那是不可能的。请解释这是为什么?Scala中如何用特质来设计出这样的效果?

Java只能单继承,JContainer不能同时继承自Container和JComponent。Scala可以通过特质解

决这个问题.

11.7 市面上有不下数十种关于Scala特质的教程,用的都是些\在叫的狗\啦,\讲哲学的青

蛙\啦之类的傻乎乎的例子。阅读和理解这些机巧的继承层级很乏味且对于理解问题没什么帮助,但自己设计一套继承层级就不同了,会很有启发。做一个你自己的关于特质的继承层级,要求体现出叠加在一起的特质,具体的和抽象的方法,以及具体的和抽象的字段

trait Fly{

def fly(){

println(\)

}