Chinaunix首页 | 论坛 | 博客
  • 博客访问: 12189
  • 博文数量: 16
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 170
  • 用 户 组: 普通用户
  • 注册时间: 2017-01-20 10:16
文章分类

全部博文(16)

文章存档

2017年(16)

我的朋友

分类: 大数据

2017-02-08 20:06:07

2.scala控制结构、函数、异常处理---小书匠,在线编辑器,MARKDOWN,Evernote,文件版本 input{ margin: 0 0 0 -20px; } .video_container{ width: 100%; display: table; text-align: center; position: relative; padding-bottom: 56.25%!important; } .slideshare_container .inner{ position: relative; width: 100%; } .slideshare_container .inner iframe{ width: 100%; height: 100%; position: absolute; top: 0; bottom: 0; left: 0; right: 0; } .video_container iframe{ width: 100%; height: 100%; position: absolute; top: 0; left: 0; z-index: 1; vertical-align: middle; } kbd{ display: inline-block; padding: 3px 5px; font-size: 11px; line-height: 10px; color: #555; vertical-align: middle; background-color: #fcfcfc; border: solid 1px #ccc; border-bottom-color: #bbb; border-radius: 3px; box-shadow: inset 0 -1px 0 #bbb; } .blank_anchor_id { float: left; } .blank_anchor_id { visibility: hidden; } .blank_anchor_id:before { content: 'a'; } blockquote footer{ margin: 1em 0; font-style: italic; } blockquote footer cite { margin: 0 1em; } /*wavedrom start*/ .wavedrom_svg text, .wavedrom_svg_defs text { font-size:11pt; font-style:normal; font-variant:normal; font-weight:normal; font-stretch:normal; text-align:center; fill-opacity:1; font-family:Helvetica } .wavedrom_svg .muted, .wavedrom_svg_defs .muted { fill:#aaa } .wavedrom_svg .warning, .wavedrom_svg_defs .warning { fill:#f6b900 } .wavedrom_svg .error, .wavedrom_svg_defs .error { fill:#f60000 } .wavedrom_svg .info, .wavedrom_svg_defs .info { fill:#0041c4 } .wavedrom_svg .success, .wavedrom_svg_defs .success { fill:#00ab00 } .wavedrom_svg .h1, .wavedrom_svg_defs .h1 { font-size:33pt; font-weight:bold } .wavedrom_svg .h2, .wavedrom_svg_defs .h2 { font-size:27pt; font-weight:bold } .wavedrom_svg .h3, .wavedrom_svg_defs .h3 { font-size:20pt; font-weight:bold } .wavedrom_svg .h4, .wavedrom_svg_defs .h4 { font-size:14pt; font-weight:bold } .wavedrom_svg .h5, .wavedrom_svg_defs .h5 { font-size:11pt; font-weight:bold } .wavedrom_svg .h6, .wavedrom_svg_defs .h6 { font-size:8pt; font-weight:bold } .wavedrom_svg_defs .s1 { fill:none; stroke:#000; stroke-width:1; stroke-linecap:round; stroke-linejoin:miter; stroke-miterlimit:4; stroke-opacity:1; stroke-dasharray:none } .wavedrom_svg_defs .s2 { fill:none; stroke:#000; stroke-width:0.5; stroke-linecap:round; stroke-linejoin:miter; stroke-miterlimit:4; stroke-opacity:1; stroke-dasharray:none } .wavedrom_svg_defs .s3 { color:#000; fill:none; stroke:#000; stroke-width:1; stroke-linecap:round; stroke-linejoin:miter; stroke-miterlimit:4; stroke-opacity:1; stroke-dasharray:1,3; stroke-dashoffset:0; marker:none; visibility:visible; display:inline; overflow:visible; enable-background:accumulate } .wavedrom_svg_defs .s4 { color:#000; fill:none; stroke:#000; stroke-width:1; stroke-linecap:round; stroke-linejoin:miter; stroke-miterlimit:4; stroke-opacity:1; stroke-dasharray:none; stroke-dashoffset:0; marker:none; visibility:visible; display:inline; overflow:visible } .wavedrom_svg_defs .s5 { fill:#fff; stroke:none } .wavedrom_svg_defs .s6 { color:#000; fill:#ffffb4; fill-opacity:1; fill-rule:nonzero; stroke:none; stroke-width:1px; marker:none; visibility:visible; display:inline; overflow:visible; enable-background:accumulate } .wavedrom_svg_defs .s7 { color:#000; fill:#ffe0b9; fill-opacity:1; fill-rule:nonzero; stroke:none; stroke-width:1px; marker:none; visibility:visible; display:inline; overflow:visible; enable-background:accumulate } .wavedrom_svg_defs .s8 { color:#000; fill:#b9e0ff; fill-opacity:1; fill-rule:nonzero; stroke:none; stroke-width:1px; marker:none; visibility:visible; display:inline; overflow:visible; enable-background:accumulate } .wavedrom_svg_defs .s9 { fill:#000; fill-opacity:1; stroke:none } .wavedrom_svg_defs .s10 { color:#000; fill:#fff; fill-opacity:1; fill-rule:nonzero; stroke:none; stroke-width:1px; marker:none; visibility:visible; display:inline; overflow:visible; enable-background:accumulate } .wavedrom_svg_defs .s11 { fill:#0041c4; fill-opacity:1; stroke:none } .wavedrom_svg_defs .s12 { fill:none; stroke:#0041c4; stroke-width:1; stroke-linecap:round; stroke-linejoin:miter; stroke-miterlimit:4; stroke-opacity:1; stroke-dasharray:none } /*wavedrom stop*/ /* Orginal Style from ethanschoonover.com/solarized (c) Jeremy Hull */ .hljs { display: block; overflow-x: auto; padding: 0.5em; background: #fdf6e3; color: #657b83; -webkit-text-size-adjust: none; } .hljs-comment, .diff .hljs-header, .hljs-doctype, .hljs-pi, .lisp .hljs-string, .hljs-javadoc { color: #93a1a1; } /* Solarized Green */ .hljs-keyword, .hljs-winutils, .method, .hljs-addition, .css .hljs-tag, .hljs-request, .hljs-status, .nginx .hljs-title { color: #859900; } /* Solarized Cyan */ .hljs-number, .hljs-command, .hljs-string, .hljs-tag .hljs-value, .hljs-rule .hljs-value, .hljs-phpdoc, .hljs-dartdoc, .tex .hljs-formula, .hljs-regexp, .hljs-hexcolor, .hljs-link_url { color: #2aa198; } /* Solarized Blue */ .hljs-title, .hljs-localvars, .hljs-chunk, .hljs-decorator, .hljs-built_in, .hljs-identifier, .vhdl .hljs-literal, .hljs-id, .css .hljs-function, .hljs-name { color: #268bd2; } /* Solarized Yellow */ .hljs-attribute, .hljs-variable, .lisp .hljs-body, .smalltalk .hljs-number, .hljs-constant, .hljs-class .hljs-title, .hljs-parent, .hljs-type, .hljs-link_reference { color: #b58900; } /* Solarized Orange */ .hljs-preprocessor, .hljs-preprocessor .hljs-keyword, .hljs-pragma, .hljs-shebang, .hljs-symbol, .hljs-symbol .hljs-string, .diff .hljs-change, .hljs-special, .hljs-attr_selector, .hljs-subst, .hljs-cdata, .css .hljs-pseudo, .hljs-header { color: #cb4b16; } /* Solarized Red */ .hljs-deletion, .hljs-important { color: #dc322f; } /* Solarized Violet */ .hljs-link_label { color: #6c71c4; } .tex .hljs-formula { background: #eee8d5; }

2.scala控制结构、函数、异常处理

2.1条件表达式

(1)if表达式有返回值,如val result = if(x>0) 0 else -1 ,则result值可能为0或-1
(2)if表达式分支语句返回值的类型不一致时,则表达式返回值的类型是它们共同的父类型Any
val result = if(x>0) 0 else "error"
则result的类型为Any
(3)若if表达式没有分支满足条件,则返回Unit

2.2块表达式

(1)块表达式的值是最后一个语句的返回值,一个块中有多个语句时用逗号隔开。如:
val result = {val x=2;val y=3;pow(x,y)}

2.3循环

(1)while循环的实现方式和java中一样。
(2)scala中的for循环写法如下:
for(i <- 1 to 10){ println(i) }
(3)for推导式。如果for循环的循环体以yield开始,则该循环会构造出一个集合,每次迭代生成集合中的一个值,如:
for(i <- 1 to 10) yield i%3 //得到Vector(1,2,0,1,2,0,1,2,0,1)

2.4函数

一个函数包含了函数名称,参数和函数体等三个元素,如:
def abs(x:Double) = if(x>=0) x else -x
如果不是递归函数,不需要给定返回值类型

2.5参数

(1)默认参数。调用某些函数时可以不用给出参数,此时使用默认参数。如:
def check(path:String,name:String="home")
使用check("local")时传入的两个参数分别为local和默认的home
(2)带名参数。在提供参数值的时候指定参数名,带名参数可以打乱参数列表的顺序,但是带名参数和不带名参数共同使用时,需要将不带名参数放在带名参数之前。
(3)变长参数。参数列表可以为同类型的多个参数。如:
def sum(num:Int*)={ val count = 0 for(i <-num){ count +=i } }
函数得到的是一个序列,但是不代表可以传入一个序列。如sum(1 to 5)这种写法是错误的。

2.6懒值

当val被生命为lazy时,它的初始化会被推迟,直到其被第一次取值时。如:
val a = 0 lazy val b = a*10

2.7异常处理

scala中异常处理与java类似。一般写法如下:
try{ process }catch{ case e:Throwable => some process case _ => other process }finally{ }

阅读(226) | 评论(0) | 转发(0) |
0

上一篇:scala基础

下一篇:3.scala容器

给主人留下些什么吧!~~