Scala-Unit-2-Scala基础语法1
一、Scala程序的开始->HelloScala
这里的操作如同java的helloworld程序,直接放代码!
object HelloScala{
def main(args:Array[String]){
println("HelloScala")
}
}
在命令行操作中输入命令:
scalac HelloScala.scala
scala HelloScala
二、Scala的数据类型
Scala与java相同,有八种基本数据类型:
Byte/Char/Short/Int/Long/Float/Double/Boolean
还有Unit类型(与java中void相似),表示无值,主要用于不返回任何结果的结果类型
注意:Scala中没有包装类
三、Scala定义变量
两个关键字:val、var
val:定义的变量值是不可变的
var:定义的变量值是可变的
eg. val a:Long = 1 var b:String = "我很帅"
注意:Scala编译器会自动的推断数据类型!!
eg. val a = 1 (a自动为Int类型)
var s = "you are ugly" (s自动为String类型)
val h = println("cool") (h自动为Unit类型)
四、条件表达式(一下命令都是在windows命令行操作中运行的)
if语句:
val x = 2
val y = if(x>0) 1 esle 2
val m = if(x<0) -1 if(x>1) 1 else 0
混合类型:
val z = if(x>0) "true" else 1
输出语句为: z:Any = "true"
注意:Any相当于Java中的object基类,它包含Anyval和AnyRef
Anyval:包含scala所有类型、AnyRef:包含Scala clsaaes与Java classes
五、块表达式
相当于java中的程序快,在Scala中用{}包裹的一些列表达式及块表达式,块中最后一个表达式的值就是块的值。
可以在idea中创建Scala工程展示
sbt版本:1.1.0 scala版本:2.11.8
创建Scala类注意,kind类型选择object
六、循环(一下是在Windows命令行操作中运行,其中”<-“相当于java中for循环变量的意思)
val rs = 1 to 10 //Scala会创建一个包含从1到10的10个元素的数组rs
for (x <- rs) println(x) //便利数组rs,并输出每个元素
val arr = Array(1,3,5) //创建不可变数组arr,包含1,3,5三个元素
for (i <- arr) println(i) //便利数组arr并输出每个元素
高级for循环:
for(i <- 1 to 5 ;j <- 1 to 10 if i != j) print((10 * i + j) + " ")
for(i <- 1 to 10) yield i*10 //关键字yield:生成一个新的集合
val ab = for(i <- 1 to 10;if(i % 2 == 0)) yeild i
注意:1 to 10 同 1.to(10) 表达的意思是一样的,to是一个方法,在Scala中可以省略“.”
1.to(10).map(_*100) //创建一个元素为1到10的集合并将每个元素都乘以100
map:取出元素 _:代表集合中的元素
七、运算符
在Scala中,+、-、*、/、%的作用和Java中是一样的,但特别的是他们都是方法
eg. 1 + 2 和 1.+(2) 的结果是一样的
object ScalaDemo2{
def mian(args:Array[String]):unit={
println(m1(1,6))
println(m2(3,6))
} def m1(a:Int,b:Int):Int={
a+b
} def m2(a:Int,b:Int):Int=a*b }
Scala-Unit-2-Scala基础语法1的更多相关文章
- Spark入门到精通--(第二节)Scala编程详解基础语法
Scala是什么? Scala是以实现scaleable language为初衷设计出来的一门语言.官方中,称它是object-oriented language和functional languag ...
- Scala - 快速学习03 - 基础语法
1- 变量 变量 mutable variable 在程序运行过程中其值可能发生改变的量 关键词var定义变量,定义时直接进行求值 常量 immutable variable 在程序运行过程中其值不会 ...
- Scala(二)——基础语法(与Java的区分)和函数式编程
Scala快速入门(二) 一.键盘输入 关于基本类型的运算,以及复制运算,条件运算,运算符等知识,均和Java语言一样,这里不过多叙述. val name = StdIn.readLine() Std ...
- Scala学习教程笔记一之基础语法,条件控制,循环控制,函数,数组,集合
前言:Scala的安装教程:http://www.cnblogs.com/biehongli/p/8065679.html 1:Scala之基础语法学习笔记: :声明val变量:可以使用val来声明变 ...
- 【Scala学习之一】 Scala基础语法
环境 虚拟机:VMware 10 Linux版本:CentOS-6.5-x86_64 客户端:Xshell4 FTP:Xftp4 jdk1.8 scala-2.10.4(依赖jdk1.8) spark ...
- Scala简介及基础语法
一.scala简介 官网:https://www.scala-lang.org/ Scala语言很强大,集成了面向对象和函数式编程的特点. 运行在JVM(jdk). 大数据中为什么学习scala? s ...
- 1.scala基础语法总结
Scala基础语法总结:Scala 与 Java 的最大区别是:Scala 语句末尾的分号 ; 是可选的.如果一行里写多个语句那么分号是需要的 val s = "菜鸟教程"; pr ...
- Scala学习(一)——基础语法
Scala语言是一种面向对象语言,结合了命令式(imperative)和函数式(functional)编程风格,其设计理念是创造一种更好地支持组件的语言. 特性 多范式(Multi-Paradigm) ...
- Scala基础语法 (一)
如果你之前是一名 Java 程序员,并了解 Java 语言的基础知识,那么你能很快学会 Scala 的基础语法. Scala 与 Java 的最大区别是:Scala 语句末尾的分号 ; 是可选的. 我 ...
- Scala入门系列(一):基础语法
Scala基础语法 Scala与JAVA的关系 Scala是基于Java虚拟机,也就是JVM的一门编程语言,所有Scala的代码都需要经过编译为字节码,然后交由Java虚拟机来运行. 所以Scala和 ...
随机推荐
- linq基本操作
一.Linq有两种语法: 1. 方法语法 2. 查询语法 下面举个例子看看这两种方法的区别 比如现在有一个学生类 public class student { public string user ...
- Modbus库开发笔记之一:实现功能的基本设计
Modbus作为开放式的工业通讯协议,在各种工业设备中应用极其广泛.本人也使用Modbus通讯很多年了,或者用现成的,或者针对具体应用开发,一直以来都想要开发一个比较通用的协议栈能在后续的项目中复用, ...
- Oracle11g 体系结构
一:Oracle11g 体系结构 二:逻辑储存结构 二.1:数据块(data blocks) ----通过 v$parameter数据字典来查询oracle标准数据块的大小. SYS@orcl> ...
- Confluence 6 PostgreSQL 测试你的数据库连接
在你的数据库设置界面,有一个 测试连接(Test connection)按钮可以检查: Confluence 可以连接你的数据库服务器 数据库字符集的编码是否设置正确 你的数据库用户是否有正确的权限可 ...
- Confluence 6 选择一个默认的语言
管理员可以设置应用到你 Confluence 站点所有空间的默认语言.请注意,一个独立的用户可以在他们自己的属性中选择他们独立的语言属性. 设定默认的语言 在 Confluence 站点中修改默认的语 ...
- 电子书转换为PDF格式
目录 一.mobi 转换 pdf 步骤 二.查看转换后的结果目录 三.将PDF还原文件名且移出至新目录 背景:当我们从网上下载一些电子小说或书籍的时候,一般文件的格式可能是.epub..mobi等.这 ...
- 断路器Feign
Feign是自带断路器,需要在配置文件中开启断路器 改造消费者项目(FeignDemo) 1.在application.yml配置文件中开启断路器 eureka: client: service-ur ...
- Nginx的进程模型及高可用方案(OpenResty)
1. Nginx 进程模型简介 Nginx默认采用多进程工作方式,Nginx启动后,会运行一个master进程和多个worker进程.其中master充当整个进程组与用户的交互接口,同时对进程进行监护 ...
- Zookeeper安装(本地,伪分布式,集群)
概述 ZooKeeper是一个分布式开源框架,提供了协调分布式应用的基本服务,它向外部应用暴露一组通用服务——分布式同步(Distributed Synchronization).命名服务(Namin ...
- 【python】多进程共享变量
有一个字典变量,需要在多个进程间共享 使用Manager, 下面是一个小例子. 注意使用json前需要将类型转换. #!/usr/bin/python # coding=utf-8 import js ...