`
fengfeng925
  • 浏览: 107064 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Scala语言入门初探

阅读更多
    用Java语言开发许久了,一直接触指令式的语言开发,同时也做的多了,也逐渐感觉到了静态语言的一些弊病。Scala的出现,可以使Java程序员平滑的过度,Scala语言也是运行在JVM上的,可以与Java无缝交互;Scala是面向对象的,可以通过提升接口的抽象级别来帮助管理复杂性。Scala是简洁的,Scala程序员曾报告说,与Java比起来,它的代码行数可以减少到Java的1/10,哈哈,是不是有些夸张呢?个人觉得,如果能减少三分之一,就非常成功了;Scala是静态的,它以Java的内嵌类型系统为基础,允许使用泛型参数化类型,用交集组合型类型和抽象类型隐藏实现细节,从而能够设计出安全而又能灵活使用的接口。

    我们先来安装Scala的开发包,我的版本是scala-2.9.0.1.zip,安装方式解压就可以,环境变量和Jdk的没什么区别,指向到bin目录下就可以了,打开dos窗口,运行scala,出现下面结结果就表示安装成功了
   


    好了,让我们开始Scala之旅吧。
    在Scala中,分号是可选的,你可以写或者不写;定义类和构造函数,Java中一般这么写
public class MyTest {

	private int id;
	
	private int index;
	
	public MyTest(int id, int index) {
		this.id = id;
		this.index = index;
	}
}

而在Scala中,可以这么写
class MyTest(id: Int, index: Int)

除了这些特性,尤其值得一提的是Scala是静态类型的语言,它支持指令式的编程,但更推荐的使用函数式的编程。比如下面的代码
object HelloWorld {

  def main(args: Array[String]): Unit = {
    var i = 0
    while(i < args.length) {
      println(args(i))
      i += 1
    }
  }

}

我可以使用scalac HelloWorld.scala使他生成class字节码,也可以直接在JVM上执行,
scala HelloWorld.scala Hello World
打印结果将是 Hello World
大家不觉得这样有一丁点儿复杂吗,来看看Scala的函数式的编程是什么样的
object HelloWorld {

  def main(args: Array[String]): Unit = {
    args.foreach(arg => print(arg + " "))
  }

}

arg就是你临时定义的变量,Scala默认为其开辟了临时的String变量arg。

体验了最初的简单函数式风格,我们再看下Scala中如何使用数组,在Java中,使用一个最简单数组是这样的
public class ArrayTest {

	public static void main(String[] args) {
		String[] strs = new String[]{"Hello", "World", "!"};
		for(String str : strs) {
			System.out.println(str);
		}
	}
}

在Scala中,同样是通过new来实例化对象,实例化过程中,可以用值和类型使对象参数化,使用值参数化实例可以通过把值传递给构造器的圆括号来实现,比如,Scala中数组是这么实现的,值得一提的是,在Scala中,数组是可变数据结构,这是和Java中有区别的地方
object ArrayTest {

  def main(args: Array[String]): Unit = {
    var greetString = new Array[String](3)
    greetString(0) = "Hello"
    greetString(1) = "World"
    greetString(2) = "!"
    
    for(i <- 0 to 2) {
      println(greetString(i))
    }
  }

}


i <- 这个表达式是表示左边的涵盖在右边范围之内。
下面我们来看看List,在Java中,List是可变的结构序列,而在Scala中,List是不可变的,在Scala中,List是不可变的数据结构,这么设计是为了函数式编程而设计的,奇特的是,Scala中并不需要通过new来创建List对象,比如下面一个例子,我创建了两个集合,并且把它们循环打印出来。
def main(args: Array[String]): Unit = { 
    var list1 = List("aaa", "bbb", "ccc")
    var list2 = List("ddd")
    var list3 = list1 ::: list2
    list3.foreach(list => print(list + " "))
  }

打出的结果就是 aaa bbb ccc ddd

我们再来看看Set和Map,Scala致力于充分利用函数式和指令式两方面的好处,所以它的集合库区分为可变型和不可变型,都承接与Set,他们分别在Scala的不同包里。在Java中,我们称为“实现”了接口,而在Scala中,我们称为“扩展”或“混入”,下面我分别用Scala中的HashSet和HashMap的不可变数据类型,来做例子
object SetTest {

  def main(args: Array[String]): Unit = {
    var set = HashSet("b", 3, "c")
    set += "very"
    set.foreach(value => print(value + " "))
  }

}


这是Set的,下面是关于Map的
object MapTest {

  def main(args: Array[String]): Unit = { 
    var map = HashMap(1 -> "a", 2 -> "b", 3 -> "c")
    map += (4 -> "d")
    map.foreach(value => print(value + " "))
  }

}

Scala的程序,只要后缀名命名为.scala就可以了。同时Eclipse也内置了对Scala的支持,安装插件的网址是http://download.scala-ide.org/nightly-update-wip-experiment-2.9.0.final
大家可以自行安装,安装完后就可以在Eclipse中运行了,如下图


现在对函数式编程有个了最初体会了,呵呵,以后还会继续探讨关于Scala函数式编程带来的一些好处,大家相互学习,还请多多指教。
  • 大小: 8.4 KB
  • 大小: 17.6 KB
分享到:
评论
13 楼 jilen 2011-06-24  
scala是静态类型,但是有类型推断,所以可以减少很多累赘代码。通常静态类型语音代码有很多累赘的类型信息。
开始我也感觉到scala好像是个不伦不类的怪物,即不像erlang,lisp那么纯粹functional,又不是那么单纯的命令式,感觉有许多稀奇古怪的特性。不过现在又感觉scala对象模型和函数式编程结合的还是很完美的,martin也是坚信这一点才创造这个东西
12 楼 jilen 2011-06-24  
scala确实很不错。闭包和函数是第一类值这些思想是函数式编程语音的特点。scala了对象模型也比较不错,是我喜欢的类型。模式匹配之类的特性可以让代码更优雅。
11 楼 wanbin021614 2011-06-22  
这个我觉得自己玩玩就好 企业级的应用 java还是主流
10 楼 izat 2011-06-21  
netfishx 写道
scala跟什么静态语言的弊病怎么扯一块的,太不靠谱了吧

同上,不过楼主貌似也知道scala是静态的,这逻辑呀。
9 楼 netfishx 2011-06-21  
scala跟什么静态语言的弊病怎么扯一块的,太不靠谱了吧
8 楼 ariestiger 2011-06-20  
blue_halo 写道
为什么不能用 java 解释运行 scala生成的字节码

例如: java HelloWord

要带classpath,scala里有一个scala-library.jar,带上就行
7 楼 happysoul 2011-06-20  
groovy之父说 早知道有 Scala 这东西 他就不发明什么 groovy 了....
6 楼 guilipan 2011-06-20  
怎么没人用groovy么
5 楼 mathgl 2011-06-18  
ray_linn 写道
Scala好,主要是因为java的语法太烂,但是和C#比,Scala引入太多函数式的”污染“,个人不推崇纯函数式编程,最好只在特定环境中小规模使用。


Scala还不怎么算pure fp

我看F# 味道更重。

scala要是不想用fp,可以不用,不过这样还不如用java。
4 楼 blue_halo 2011-06-17  
为什么不能用 java 解释运行 scala生成的字节码

例如: java HelloWord
3 楼 ray_linn 2011-06-09  
Scala好,主要是因为java的语法太烂,但是和C#比,Scala引入太多函数式的”污染“,个人不推崇纯函数式编程,最好只在特定环境中小规模使用。
2 楼 fengfeng925 2011-06-09  
ray_linn 写道
这是闭包,其他语言如C#早有的东西。Scala的闭包写法和C#完全一样

new List<int>(new int[] { 1, 2, 3, 4, 5, 6, 7, 8 }).ForEach(i=>Console.WriteLine(i));

没错,在运行时创建的函数值(对象)就是闭包,没学过C#,呵呵。
1 楼 ray_linn 2011-06-09  
这是闭包,其他语言如C#早有的东西。Scala的闭包写法和C#完全一样

new List<int>(new int[] { 1, 2, 3, 4, 5, 6, 7, 8 }).ForEach(i=>Console.WriteLine(i));

相关推荐

    Scala语言入门

    ### Scala语言入门知识点详解 #### 一、Scala简介 Scala是一种多范式的编程语言,它融合了面向对象编程和函数式编程的特点。Scala语言的设计旨在提高代码的可读性和表达能力,同时保持高性能。Scala运行在Java平台...

    scala 入门PDF文档,编码规范文档 scalabook.rar

    scala 入门PDF文档,编码规范文档。 Scala 是一门多范式(multi-paradigm)的编程语言,设计初衷是要集成面向对象编程和函数式编程的各种特性。 Scala 运行在 Java 虚拟机上,并兼容现有的 Java 程序。

    Scala入门学习教程.docx

    Scala入门学习教程 本资源摘要信息为 Scala 入门学习教程,旨在帮助读者快速掌握 Scala 语言的基本概念和编程技术。该教程面向具有一定编程经验的读者,尤其是 Java 语言的开发者。 知识点一:Scala 语言简介 ...

    Scala编程语言从入门到精通

    资源名称:Scala编程语言从入门到精通资源目录:【】DesignOfScala【】ExcitedScala_7(1)【】lift-lift_23_sbt-cf313e1【】ScalaTutorial-zh_CN【】Scala_2.7.6_API【】Scala向导(前13章)【】Scala向导(前15章)-p...

    尚硅谷大数据之Scala语言核心编程.pdf

    在快速入门章节中,给出了使用IDEA开发“hello, world”程序的示例,并介绍了Scala程序的执行流程,还用Java编写了模拟代码,以此帮助初学者理解Scala语言的基本结构和概念。 书中的知识点还包括了Scala语言的转义...

    尚硅谷_韩顺平_Scala语言核心编程_PDF密码解除1

    7. **Scala的快速入门**: 初学者通常从基础语法开始,包括变量声明、函数定义、类和对象的创建,然后逐步接触更高阶的概念,如模式匹配、Actor模型、集合操作等。通过编写简单的示例程序,可以快速上手Scala编程。...

    scala编程入门教材

    Scala编程入门教材旨在引导初学者踏入Scala这一强大且多用途的编程语言的世界。Scala结合了面向对象编程(OOP)和函数式编程(FP)的特性,为开发者提供了丰富的工具来构建高效、可扩展的软件系统。以下是Scala编程...

    Scala语言规范.pdf

    Scala是一种多范式编程语言,它融合了面向对象和函数式编程的概念,旨在提供一种简洁、类型安全且高性能的编程模型。《Scala语言规范》是理解这种语言的基础,特别是对于那些想要深入学习Apache Spark或其他基于...

    Scala语言规范-2019.rar

    Scala语言规范-Scala 是一门类 Java 的编程语言,它结合了面向对象编程和函数式编程。 Scala 是纯面向对象的,每个值都是一个对象,对象的类型和行为由类定义,不同的类可以通过混入(mixin)的方式组合在一起。 Scala...

    scala语言教程及规范

    Scala是一种多范式编程语言,融合了面向对象和函数式编程的概念。它的设计目标是提供一种更高级别的抽象,使得代码简洁、可读性强,并且能够充分利用并发处理。本教程旨在帮助初学者深入理解Scala语言,并掌握其核心...

    Scala语法入门.pdf

    Scala是一门多范式编程语言,它结合了面向对象编程(OOP)和函数式编程(FP)的最佳特性。Scala运行在Java虚拟机(JVM)之上,这意味着它可以无缝地调用Java类库,并与Java代码进行交互。Scala的设计目的是简化编程任务,...

    Scala语言分析报告

    Scala是一种在Java虚拟机(JVM)上运行的高级编程语言,它巧妙地融合了面向对象和函数式编程的概念。Scala的设计目标是提高代码的可读性、安全性和可伸缩性,同时允许程序员利用多核处理器的优势进行并行处理。 在...

    Scala语言规范.zip

    Scala是一种多范式编程语言,它融合了面向对象和函数式编程的概念,旨在提供一种更高级别的抽象,使代码更加简洁、优雅。由于其与Java虚拟机(JVM)的紧密集成,Scala程序可以直接在Java平台上运行,这也是它被标记...

    scala语言pdf_带目录标签

    Scala是一种强大的多范式编程语言,它融合了面向对象和函数式编程的特性,由Martin Odersky在2003年设计并推出。Scala的名字是"Scalable Language"的缩写,意在表达其设计目标是扩展性,能够满足从小型脚本到大型...

    Spark技术实战之基础篇 -Scala语言从入门到精通 Scala编程详解 含课件和资料 共21个章节.rar

    【课程大纲】第1讲-Spark的前世今生第2讲-课程介绍、特色与价值第3讲-Scala编程:基础语法第4讲-Scala编程:条件控制与循环第5讲-Scala编程:函数入门第6讲-Scala编程:函数入门之默认参数和带名参数第7讲-Scala编程...

Global site tag (gtag.js) - Google Analytics