Scala学习(七)练习
控制结构和函数 |
1. 编写示例程序,展示为什么
package com.horstmann.impatient
不同于
package com
package horstmann
package impatient
描述: 区别是后者的上层包也可见,而串写的只有当前包范围可见
程序代码: b.scala
- package com{
- package horstmann{
- object A{
- def hi=println("I am A")
- }
- package impatient{
- object B extends App{
- def hi=A.hi
- hi
- }
- }
- }
- }
运行结果:
E:\Test>scalac b.scala
E:\Test>scala com.horstmann.impatient.B
I am A
E:\Test>
程序代码: c.scala
package com.horstmann.impatient{
object C extends App{
B.hi
A.hi
}
}
运行结果:
E:\Test>scalac c.scala
c.scala:4: error: not found: value A
A.hi
^
one error found
E:\Test>
编译时找不到A,说明串联声明时不包含上级声明
程序代码: d.scala
E:\Test>scalac d.scala
E:\Test>scala com.horstmann.impatient.C
I am A
I am A
E:\Test>
2. 编写一段让你的Scala朋友们感到困惑的代码,使用一个不在顶部的com包
程序代码: a1.scala
package com {
package horstmann {
package com {
package horstmann {
object A {
def hi = println("I am the Ghost A")
}
}
}
}
}
程序代码: a2.scala
package com {
package horstmann {
object A {
def hi =println("I am A")
}
package impatient {
object B extends App {
def hi = com.horstmann.A.hi
hi
}
}
}
}
先编译a2.scala再编译a1.scala运行结果如下:
E:\Test>scalac a2.scala
E:\Test>scalac a1.scala
E:\Test>scala com.horstmann.impatient.B
I am A
E:\Test>
先编译a1.scala再编译a1.scala运行结果如下:
E:\Test>scalac a1.scala
E:\Test>scalac a2.scala
E:\Test>scala com.horstmann.impatient.B
I am the Ghost A
E:\Test>
3. 编写一个包random,加入函数nextlnt(): Int、nextDouble(): Double和setSeed(seed : Int): Unit。生成随机数的算法采用线性同余生成器:
后值 =(前值×a+b)mod 2n
其中,a = 1664525,b =1013904223,n =32,前值的初始值为seed。
程序代码:
- package random{
- object Random {
- private val a = 1664525
- private val b = 1013904223
- private val n = 32
- private var seed=0
- private var follow:BigInt=0
- private var previous:BigInt=0
- def nextInt():Int={
- follow=(previous*a+b)%BigInt(math.pow(2, n).toLong)
- previous=follow
- (follow%Int.MaxValue).intValue()
- }
- def nextDouble():Double={
- nextInt.toDouble
- }
- def setSeed(newSeed:Int){
- seed=newSeed
- previous=seed
- }
- }
- }
- object Test extends App{
- var r =random.Random
- r.setSeed(args(0).toInt)
- for(i <- 1 to 10) println(r.nextInt())
- for(i <- 1 to 10) println(r.nextDouble())
- }
运行结果:
E:\Test>scalac Random.scala
E:\Test>scala Test 0
1013904223
1196435762
1372387050
720982837
1649599747
523159175
1476291629
601448361
33406696
351317787
1.27442629E9
1.020336477E9
4.8889166E8
1.654060783E9
2.8987765E7
6.3353937E7
8.92205936E8
1.338634754E9
1.649346937E9
6.21388933E8
E:\Test>
4. 在你看来,Scala的设计者为什么要提供package object法而不是简单地让你将函数和变量添加到包中呢
直接加函数和变量声明到包中,比如com.a.b.c。这样就跟c下面的的class或者object差 了一个层级。他们实际上是c下面的所有类的共同的上级定义。这样一来就没有了封装性。 而实现上来说估计也比较麻烦。
5. private[com] def giveRaise(rate: Double)的含义是什么,有用吗
该函数在com包下可见,可以扩大函数的可见范围
6. 编写一段程序,将Java哈希映射中的所有元素拷贝到Scala哈希映射。用引入语句重命名这两个类
程序代码:
- import java.util.{HashMap=>JHashMap}
- import scala.collection.mutable.HashMap
- object JavaMap {
- def transMapValues(javaMap:JHashMap[Any,Any]):HashMap[Any,Any]={
- val result=new HashMap[Any,Any]
- for(k <- javaMap.keySet().toArray()){
- result+=k->javaMap.get(k)
- }
- result
- }
- def main(args: Array[String]): Unit = {
- val jmap:JHashMap[Any,Any]=new JHashMap[Any,Any]
- var smap=new HashMap[Any,Any]
- for(i <- 1 to 9)
- jmap.put(i,"JavaMap"+i)
- smap=transMapValues(jmap)
- smap.foreach(println)
- }
- }
运行结果:
(8,JavaMap8)
(2,JavaMap2)
(5,JavaMap5)
(4,JavaMap4)
(7,JavaMap7)
(1,JavaMap1)
(9,JavaMap9)
(3,JavaMap3)
(6,JavaMap6)
7. 在前一个练习中,将所有引入语句移动到尽可能小的作用域里
描述:import可以放到任何区域,直接放到对象结构体当中,也没有问题
程序代码:
- object JavaMap {
- import java.util.{HashMap=>JHashMap}
- import scala.collection.mutable.HashMap
- def transMapValues(javaMap:JHashMap[Any,Any]):HashMap[Any,Any]={
- val result=new HashMap[Any,Any]
- for(k <- javaMap.keySet().toArray()){
- result+=k->javaMap.get(k)
- }
- result
- }
- def main(args: Array[String]): Unit = {
- val jmap:JHashMap[Any,Any]=new JHashMap[Any,Any]
- var smap=new HashMap[Any,Any]
- for(i <- 1 to 10)
- jmap.put(i,"JavaMap"+i)
- smap=transMapValues(jmap)
- smap.foreach(println)
- }
- }
8. 以下代码的作用是什么,这是个好主意吗
import java._
import javax._
引入了java和javax的所有内容。因为Scala会自动覆盖java的同名类,不会有冲突。即使这样,引入过多的包,也会让人很迷惑。况且scala编译就已经够慢的了
9. 编写一段程序,引人java.lang.System类,从user.name系统属性读取用户名,从Console对象读取一个密码,如果密码不是" secret",则在标准错误流中打印一个消息;如果密码是" secret",则在标准输出流中打印一个问候消息。不要使用任其他引入,也不要使用任何限定词,即带句点的那种
程序代码:
- object Sys{
- import scala.io.StdIn
- import java.lang.System._
- def main(args: Array[String]): Unit = {
- val pass=StdIn.readLine()
- if(pass=="secret"){
- val name=getProperty("user.name")
- out.printf("Greetings,%s!",name)
- }else{
- err.println("error")
- }
- }
- }
运行结果:
secret
Greetings,hadoop!
10. 除了StringBuilder,还有那些java.lang的成员是被scala包覆盖的
Console,Math, 还有基本类型包装对象,Long,Double,Char,Short等等都被Scala覆盖了。
如果,您认为阅读这篇博客让您有些收获,不妨点击一下右下角的【推荐】。
如果,您希望更容易地发现我的新博客,不妨点击一下左下角的【关注我】。
如果,您对我的博客所讲述的内容有兴趣,请继续关注我的后续博客,我是【Sunddenly】。本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
Scala学习(七)练习的更多相关文章
- Scala学习七——包和引入
一.本章要点 包也可也可以像内部类那样嵌套 包路径不是绝对路径 包声明链x.y.z并不自动将中间包x和x.y变成可见 位于文件顶部不带花括号的包声明在整个文件范围内有效 包对象可以持有函数和变量 引入 ...
- Scala学习(七)---包和引入
包和引入 摘要: 在本篇中,你将会了解到Scala中的包和引入语句是如何工作的.相比Java不论是包还是引入都更加符合常规,也更灵活一些.本篇的要点包括: 1. 包也可以像内部类那样嵌套 2. 包路径 ...
- Scala学习资源
Scala学习资源: Scala官方网站:http://www.scala-lang.org/ Scala github:https://github.com/scala/scala Twitter ...
- 【Todo】【读书笔记】大数据Spark企业级实战版 & Scala学习
下了这本<大数据Spark企业级实战版>, 另外还有一本<Spark大数据处理:技术.应用与性能优化(全)> 先看前一篇. 根据书里的前言里面,对于阅读顺序的建议.先看最后的S ...
- MyBatis学习七:spring和MyBatis整合
<\mybatis\day02\16mybatis和spring整合-sqlSessionFactory配置.avi;> MyBatis学习七:spring和MyBatis整合.逆向工程 ...
- 机器学习(三)--- scala学习笔记
Scala是一门多范式的编程语言,一种类似Java的编程语言,设计初衷是实现可伸缩的语言.并集成面向对象编程和函数式编程的各种特性. Spark是UC Berkeley AMP lab所开源的类Had ...
- SVG 学习<七> SVG的路径——path(1)直线命令、弧线命令
目录 SVG 学习<一>基础图形及线段 SVG 学习<二>进阶 SVG世界,视野,视窗 stroke属性 svg分组 SVG 学习<三>渐变 SVG 学习<四 ...
- 【Scala】Scala学习资料
Scala学习资料 java 树形 分类器_百度搜索 决策树分类器-Java实现 - CSDN博客 KNN分类器-Java实现 - CSDN博客 学习:java设计模式—分类 - 飞翔荷兰人 - 博客 ...
- Scala学习网址
scala学习网址为:https://twitter.github.io/scala_school/zh_cn https://www.zhihu.com/question/26707124
随机推荐
- Python:GUI之tkinter学习笔记1控件的介绍及使用
相关内容: tkinter的使用 1.模块的导入 2.使用 3.控件介绍 Tk Button Label Frame Toplevel Menu Menubutton Canvas Entry Mes ...
- sysbench对MySQL的压测,使用sysbench压测磁盘io
QPS - query per secondTPS - transaction per second 不是特别关注,每个业务场景中事务标准是不一样的 Ⅰ.sysbench测试框架 Ⅱ.常用测试脚本 [ ...
- MyEclipse10或者eclipse中配置开发Python的Pydev插件安装教程
注意使用LiClipse的用户 PyDev已经预装在LiClipse中,所以可以跳过这一步(请注意,如果使用LiClipse,PyDev不能单独安装或更新,因为它必须始终作为一个整体更新). 必需品 ...
- ccf--20140303--命令行选项
本题是常规思路,这里要注意:1)带参命令没有参数和参数错误时终止2)命令不存在时终止3)命令都是错误的,不以—开头. 题目和代码如下: 问题描述 试题编号: 201403-3 试题名称: 命令行选项 ...
- Vs .Net Framework 灵活配置
背景:我们开发和部署项目时都是通过注释某些配置项 比如: 在调试时就注释掉生产的配置项,在生产时又要改回来,只有一个还好,如果多的话就会非常容易出错. 问题1:在发布时容易出错,需要控制发布时根据配置 ...
- 浅copy与深copy举例
例1: #!/usr/bin/env python import copy d1 = {'x':1,'y':2,'z':[3,4.5]} d2 = d1 d3 = d1.copy() d4 = co ...
- nginx配置静态资源访问
本篇配置使用场景:本地通过浏览器访问linux上某个文件夹下的文件: 1.安装jdk及nginx步骤省略 2.进入正题 (1) 查看nginx安装路径:[root@localhost conf]# w ...
- 回文数的golang实现
判断一个整数是否是回文数.回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数 输入: 输出: true 输入: - 输出: false 解释: 从左向右读, 为 - . 从右向左读, 为 - ...
- div放在li标签中,无法撑开li标签的问题
作为一个前端菜鸟,我又碰到问题了,今天把div放到li标签中,发现div并没有把li标签撑开,而是在li标签边界之外,具体情况如下图所示: 那么,怎样才能达到预期的效果(每个li中放置一个div标签, ...
- Hadoop优化 第一篇 : HDFS/MapReduce
比较惭愧,博客很久(半年)没更新了.最近也自己搭了个博客,wordpress玩的还不是很熟,感兴趣的朋友可以多多交流哈!地址是:http://www.leocook.org/ 另外,我建了个QQ群:3 ...