《快学scala第二版》第七章 练习答案

2023-11-01 06:48

本文主要是介绍《快学scala第二版》第七章 练习答案,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

7.1 编写示例程序,展示为什么
package com.horstmann.impatient
不同于
package com
package horstmann
package impatient

这个问题书里7.3节 串联式包语句说了:限定可见的成员。实例书里也有就不赘述了。

7.2 编写一段让你的Scala朋友们感到困惑的代码,使用一个不在顶部的com包。

7.3 编写一个包random, 加入函数nextInt(): Int 、 nextDouble(): Double 和 setSeed(seed: Int):Unit。生成随机数的算法采用线性同余生成器:
后值 = (前值 * a + b)mod 2 ^n
其中, a = 1664525, b = 1013904223, n = 32, 前值的初始值为seed

package randomobject Random {var seed : Int = 0val a = 1664525val b = 1013904223val n = 32def nextInt() : Int = {var value = (seed * a + b) % math.pow(2, 32)value.toInt}def nextDouble() : Double = {var value = (seed * a + b) % math.pow(2, 32)value.toDouble}def setSeed(seed : Int) : Unit = {this.seed = seed}
}

7.4 在你看来,Scala的设计者为什么要提供 package object 语法,而不是简单地让你将函数和变量添加到包中呢?

7.5 private[com] def giveRaise(rate: Double)的含义是什么?有用吗?
在 com 包中可见,其他包不能访问。

7.6 编写一段程序,将 Java 哈希映射中的所有元素复制到 Scala 哈希映射。用引入语句重命名这两个类。

import java.util.{HashMap => JavaHashMap}
import scala.collection.mutable.{HashMap => ScalaHashMap}
def copy[A,B](source: JavaHashMap[A,B], target: ScalaHashMap[A,B]) = {import scala.collection.JavaConverters._for ((k,v) <- source.asScala) {target(k) = v}target
}
val source: JavaHashMap[String,String] = new JavaHashMap
source.put("Foo", "Bar")
source.put("Quux", "Baz")
copy(source, new ScalaHashMap)

7.7 在前一个练习中,将所有引入语句移动到尽可能小的作用域里。

7.8 以下代码的作用是什么?这是一个好主意吗?
import java._
import javax._
不是,语句使java和javax下的所有包可见。

7.9 编写一段程序,引入 java.lang.System类,从 user.name 系统属性读取用户名,从 StdIn 对象读取一个密码。如果密码不是“secret”,则在标准输出流中打印一个问候消息。不要使用任何其他引入,也不要使用任何限定词(带句点的那种)。

def main(args: Array[String]): Unit = {import java.lang.System._var name = getProperty("user.name")var secret = StdIn.readLine()if (!"secret".equals(secret)){println(s"${name} Hello")}}

7.10 除了 StringBuilder 还有哪些 java.lang 的成员是被 scala 包覆盖的?
比对java.lang下的类和scala包下的类
Array, Byte, Boolean, Char, Double 等

这篇关于《快学scala第二版》第七章 练习答案的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/321219

相关文章

闲置电脑也能活出第二春?鲁大师AiNAS让你动动手指就能轻松部署

对于大多数人而言,在这个“数据爆炸”的时代或多或少都遇到过存储告急的情况,这使得“存储焦虑”不再是个别现象,而将会是随着软件的不断臃肿而越来越普遍的情况。从不少手机厂商都开始将存储上限提升至1TB可以见得,我们似乎正处在互联网信息飞速增长的阶段,对于存储的需求也将会不断扩大。对于苹果用户而言,这一问题愈发严峻,毕竟512GB和1TB版本的iPhone可不是人人都消费得起的,因此成熟的外置存储方案开

poj 3104 二分答案

题意: n件湿度为num的衣服,每秒钟自己可以蒸发掉1个湿度。 然而如果使用了暖炉,每秒可以烧掉k个湿度,但不计算蒸发了。 现在问这么多的衣服,怎么烧事件最短。 解析: 二分答案咯。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <c

RabbitMQ练习(AMQP 0-9-1 Overview)

1、What is AMQP 0-9-1 AMQP 0-9-1(高级消息队列协议)是一种网络协议,它允许遵从该协议的客户端(Publisher或者Consumer)应用程序与遵从该协议的消息中间件代理(Broker,如RabbitMQ)进行通信。 AMQP 0-9-1模型的核心概念包括消息发布者(producers/publisher)、消息(messages)、交换机(exchanges)、

《数据结构(C语言版)第二版》第八章-排序(8.3-交换排序、8.4-选择排序)

8.3 交换排序 8.3.1 冒泡排序 【算法特点】 (1) 稳定排序。 (2) 可用于链式存储结构。 (3) 移动记录次数较多,算法平均时间性能比直接插入排序差。当初始记录无序,n较大时, 此算法不宜采用。 #include <stdio.h>#include <stdlib.h>#define MAXSIZE 26typedef int KeyType;typedef char In

CSP 2023 提高级第一轮 CSP-S 2023初试题 完善程序第二题解析 未完

一、题目阅读 (最大值之和)给定整数序列 a0,⋯,an−1,求该序列所有非空连续子序列的最大值之和。上述参数满足 1≤n≤105 和 1≤ai≤108。 一个序列的非空连续子序列可以用两个下标 ll 和 rr(其中0≤l≤r<n0≤l≤r<n)表示,对应的序列为 al,al+1,⋯,ar​。两个非空连续子序列不同,当且仅当下标不同。 例如,当原序列为 [1,2,1,2] 时,要计算子序列 [

【Rust练习】12.枚举

练习题来自:https://practice-zh.course.rs/compound-types/enum.html 1 // 修复错误enum Number {Zero,One,Two,}enum Number1 {Zero = 0,One,Two,}// C语言风格的枚举定义enum Number2 {Zero = 0.0,One = 1.0,Two = 2.0,}fn m

MySql 事务练习

事务(transaction) -- 事务 transaction-- 事务是一组操作的集合,是一个不可分割的工作单位,事务会将所有的操作作为一个整体一起向系统提交或撤销请求-- 事务的操作要么同时成功,要么同时失败-- MySql的事务默认是自动提交的,当执行一个DML语句,MySql会立即自动隐式提交事务-- 常见案例:银行转账-- 逻辑:A给B转账1000:1.查询

html css jquery选项卡 代码练习小项目

在学习 html 和 css jquery 结合使用的时候 做好是能尝试做一些简单的小功能,来提高自己的 逻辑能力,熟悉代码的编写语法 下面分享一段代码 使用html css jquery选项卡 代码练习 <div class="box"><dl class="tab"><dd class="active">手机</dd><dd>家电</dd><dd>服装</dd><dd>数码</dd><dd

java线程深度解析(一)——java new 接口?匿名内部类给你答案

http://blog.csdn.net/daybreak1209/article/details/51305477 一、内部类 1、内部类初识 一般,一个类里主要包含类的方法和属性,但在Java中还提出在类中继续定义类(内部类)的概念。 内部类的定义:类的内部定义类 先来看一个实例 [html]  view plain copy pu

【附答案】C/C++ 最常见50道面试题

文章目录 面试题 1:深入探讨变量的声明与定义的区别面试题 2:编写比较“零值”的`if`语句面试题 3:深入理解`sizeof`与`strlen`的差异面试题 4:解析C与C++中`static`关键字的不同用途面试题 5:比较C语言的`malloc`与C++的`new`面试题 6:实现一个“标准”的`MIN`宏面试题 7:指针是否可以是`volatile`面试题 8:探讨`a`和`&a`