十分钟带汝入门大数据开发语言Scala

本文涉及的产品
云原生大数据计算服务MaxCompute,500CU*H 100GB 3个月
云原生大数据计算服务 MaxCompute,5000CU*H 100GB 3个月
简介: Scala是一门多范式的编程语言,一种类似Java的编程语言 ,设计初衷是实现可伸缩的语言 、并集成面向对象编程和函数式编程的各种特性。目前最主流的大数据开发框架Spark的实现就是通过Scala去实现的。Scala可以与Java互操作。它用scalac这个编译器把源文件编译成Java的class文件(即在JVM上运行的字节码),也可以从Scala中调用所有的Java类库,也同样可以从Java应用程序中调用Scala的代码。

一、概述

Scala是一门多范式的编程语言,一种类似Java的编程语言 ,设计初衷是实现可伸缩的语言 、并集成面向对象编程和函数式编程的各种特性。目前最主流的大数据开发框架Spark的实现就是通过Scala去实现的。Scala可以与Java互操作。它用scalac这个编译器把源文件编译成Java的class文件(即在JVM上运行的字节码),也可以从Scala中调用所有的Java类库,也同样可以从Java应用程序中调用Scala的代码。

Scala 与 Java 的关系

Scala是基于Java去实现的,可以理解为是对Java的一个扩展。我们都知道C语言和C++的关系,那么就可以把Scala看作是Java++一样。Java编写的.java程序编译生成.class字节码文件,最后由JVM翻译为机器码然后去执行。Scala也是类似,但是不同的是Scala编写的.scala程序,编译生成.classx$.class两个文件,也是在JVM上执行的。

Scala的特点

  • Scala是一门多范式的编程语言,Scala支持面向对象和函数式编程。
  • Scala编写起来非常简洁高效
  • Scala源代码(.scala)会被编译成Java字节码(.class),然后运行于JVM之上,并可以调用现有的Java类库,实现两种语言的无缝对接。

二、搭建环境

第一步:在本地安装JDK8环境。点此查看jdk安装具体步骤

在这里插入图片描述

第二步:在Scala官网下载安装包到本地。官网下载地址:https://www.scala-lang.org/download/all.html

选择对应的Scala版本进行下载。在这里插入图片描述在这里插入图片描述
在这里插入图片描述
第三步:配置环境变量

点击此电脑,选择高级系统选项,点击环境变量,新建一个SCALA_HOME,在path中添加%SCALA_HOME%\bin

在这里插入图片描述
在这里插入图片描述

配置完成后,在dos窗口测试,输入scala之后进入scala shell表示配置成功!

在这里插入图片描述

测试一个简单的案例:计算两数之和。

在这里插入图片描述

三、入门案例

创建一个.scala文件命名为HelloScala.scala,编写第一个scala代码。

在这里插入图片描述

进入DOS窗口:输入scalac HelloScala.scala编译生成.class文件

在这里插入图片描述

然后输入scala HelloScala运行成功!

在这里插入图片描述

scala代码基本语法说明

object HelloScala{
    def main(args: Array[String]):Unit ={
        println("Hello Scala")
    }     
}
  def 方法名称(参数名称: 参数类型): 方法返回值类型 = { 方法体 }
  • object: 为一个关键字,表示声明一个单例对象(伴生对象)
  • main方法:外部直接调用的方法
  • Unit: 空返回值类型,相当于void
  • scala中每行代码结束无需分号结束
  • Scala中的注释和Java中的注释是一样的

四、IDEA中开发Scala程序

默认情况下 IDEA 不支持 Scala 的开发,需要安装 Scala 插件及相关配置。请看如下步骤:

配置步骤

首先打开idea,点击右上角的File,选择settings

在这里插入图片描述
然后选择plugs,输入Scala,提示出Scala插件,点击install,安装完成后重启idea,插件安装成功。

在这里插入图片描述
右击项目名称,点击Add Framework support,勾选Scala,选择对应的配置

在这里插入图片描述

创建一个maven工程,在main目录下创建新的文件夹,命名为scala

在这里插入图片描述

右键文件夹,选择make directory as --> soures root

在这里插入图片描述

创建scala 对象

在这里插入图片描述
在这里插入图片描述

至此,在idea中编写scala代码完整的步骤就结束了,接下来写一个测试代码验证一下!

在这里插入图片描述

测试代码

编写scala代码:

object Test {
  def main(args: Array[String]): Unit = {
    println("Hello Scala")
  }
}

测试成功:

在这里插入图片描述

至此,Scala入门的全部内容就结束啦!

相关实践学习
基于Hologres轻松玩转一站式实时仓库
本场景介绍如何利用阿里云MaxCompute、实时计算Flink和交互式分析服务Hologres开发离线、实时数据融合分析的数据大屏应用。
SaaS 模式云数据仓库必修课
本课程由阿里云开发者社区和阿里云大数据团队共同出品,是SaaS模式云原生数据仓库领导者MaxCompute核心课程。本课程由阿里云资深产品和技术专家们从概念到方法,从场景到实践,体系化的将阿里巴巴飞天大数据平台10多年的经过验证的方法与实践深入浅出的讲给开发者们。帮助大数据开发者快速了解并掌握SaaS模式的云原生的数据仓库,助力开发者学习了解先进的技术栈,并能在实际业务中敏捷的进行大数据分析,赋能企业业务。 通过本课程可以了解SaaS模式云原生数据仓库领导者MaxCompute核心功能及典型适用场景,可应用MaxCompute实现数仓搭建,快速进行大数据分析。适合大数据工程师、大数据分析师 大量数据需要处理、存储和管理,需要搭建数据仓库?学它! 没有足够人员和经验来运维大数据平台,不想自建IDC买机器,需要免运维的大数据平台?会SQL就等于会大数据?学它! 想知道大数据用得对不对,想用更少的钱得到持续演进的数仓能力?获得极致弹性的计算资源和更好的性能,以及持续保护数据安全的生产环境?学它! 想要获得灵活的分析能力,快速洞察数据规律特征?想要兼得数据湖的灵活性与数据仓库的成长性?学它! 出品人:阿里云大数据产品及研发团队专家 产品 MaxCompute 官网 https://www.aliyun.com/product/odps 
相关文章
|
26天前
|
存储 分布式计算 Hadoop
大数据之hadoop3入门到精通(一)
大数据之hadoop3入门到精通(一)
|
2月前
|
分布式计算 Java Hadoop
Scala入门必刷的100道练习题(附答案)
Scala入门必刷的100道练习题(附答案)
489 1
|
2月前
|
Java 大数据 Scala
Scala入门【运算符和流程控制】
Scala入门【运算符和流程控制】
|
9月前
|
SQL 存储 大数据
黑马程序员-大数据入门到实战-分布式SQL计算 Hive 语法与概念
黑马程序员-大数据入门到实战-分布式SQL计算 Hive 语法与概念
100 0
|
26天前
|
分布式计算 大数据 数据处理
Python入门与大数据处理环境配置指南
**Python入门与大数据处理环境配置** Python作为高级编程语言,因其简洁语法和丰富库资源,成为数据处理、AI和大数据分析首选。本文旨在介绍Python基础和环境配置,特别是针对大数据处理的环境搭建。首先,讲解Python语言基础,包括语言概述、基本语法(变量、数据类型、控制流语句、函数和模块)。接着,讨论如何安装Python环境,以及安装NumPy、Pandas等大数据处理库。对于大数据处理,可以选择本地环境或搭建分布式环境,如Hadoop和Spark,并提供相关API示例。最后,列出环境配置中可能遇到的问题及解决方案,如版本不兼容、库安装失败等,并提供参考资料以供深入学习。
40 3
|
26天前
|
存储 分布式计算 安全
大数据之hadoop3入门到精通(三)
大数据之hadoop3入门到精通(三)
|
26天前
|
SQL 资源调度 大数据
大数据之hadoop3入门到精通(二)
大数据之hadoop3入门到精通(二)
|
2月前
|
分布式计算 大数据 Java
问我大数据怎么入门,我总结了亲身体验的学习路线推荐给她【推荐收藏】
问我大数据怎么入门,我总结了亲身体验的学习路线推荐给她【推荐收藏】
56 0
|
2月前
|
分布式计算 大数据 数据处理
[AIGC大数据基础] Spark 入门
[AIGC大数据基础] Spark 入门
237 0
|
2月前
|
分布式计算 资源调度 Hadoop
Apache Hadoop入门指南:搭建分布式大数据处理平台
【4月更文挑战第6天】本文介绍了Apache Hadoop在大数据处理中的关键作用,并引导初学者了解Hadoop的基本概念、核心组件(HDFS、YARN、MapReduce)及如何搭建分布式环境。通过配置Hadoop、格式化HDFS、启动服务和验证环境,学习者可掌握基本操作。此外,文章还提及了开发MapReduce程序、学习Hadoop生态系统和性能调优的重要性,旨在为读者提供Hadoop入门指导,助其踏入大数据处理的旅程。
659 0