大数据应用开发3-Scala笔记1

一、编程框架

Scala语言是在JVM上运行的,兼容Java语法

  • 区分大小写 -  Scala是大小写敏感的,这意味着标识Hello 和 hello在Scala中会有不同的含义。

  • 类名 - 对于所有的类名的第一个字母要大写。
    如果需要使用几个单词来构成一个类的名称,每个单词的第一个字母要大写。

  • 方法名称 - 所有的方法名称的第一个字母用小写。
    如果若干单词被用于构成方法的名称,则每个单词的第一个字母应大写。
    示例:def myMethodName()

  • Scala 使用 package 关键字定义包,在Scala将代码定义到某个包中有两种方式:

    第一种方法和 Java 一样,在文件的头定义包名,这种方法就后续所有代码都放在该包中。
    示例:def myMethodName()

    第二种方法有些类似 C#,以在一个文件中定义多个包。如:

    package com.runoob {class HelloWorld 
    }
    
  • 引用

    Scala 使用 import 关键字引用包。
    示例:import java.awt.Color // 引入Color

 

1、简单框架

object Hello {def main(args:Array[String]): Unit={println("Hello Scala!") //Scala语法System.out.println("Hello Scala!") //Java语法}
}

2.对象及伴生对象结构框架

package com.ggg.ST.Test1class Student (var name: String,var age: Int){def printInfo(): Unit = {println(name +" "+ age + " " + Student.school)}
}object Student{val school = "xmdx"def main(args: Array[String]): Unit = {val alice = new Student("alice",20)val bob = new Student("bob", 23)alice.printInfo()bob.printInfo()}
}

二、注释

Scala和Java注释一样

/*** 文档注释*/
//单行注释
/*多行注释
*/

三、常量和变量

1.Scala基本语法

Scala中常量使用val 开头、变量使用var开头(数据类型比较明显的可以自动识别出来,可以不写)

基本语法:

var 变量名 [:变量类型] = 初始值          var i:Int =10

val 常量名 [:  常量类型] = 初始值           val j:   Int = 20

注意:

1.能用常量的地方不用变量

2.var 修饰的对象引用可以改变,val 修饰的对象则不可改变,但对象的状态(值) 却是可以改变的。(比如:自定义对象、数组、集合等等)

    //声明一个变量的通用语法var a : Int = 10//(1)声明变量时,类型可以省略,编译器自动推导,即类型推导var age = 18age = 30//(2)类型确定后,就不能修改,说明 Scala 是强数据类型语言。
//    age = "sa"//(3)变量声明时,必须要有初始值

2.常量和变量名规则

Scala和Java的命名规则基本一致 ,但细节上还是略有不同

(1)必须以字母或下划线开头,后接字母、数字、下划线

(2)以操作符开头,只能包含操作符(+-*/#!等)

(3)用反引号`......`包括的任何字符串,包括Scala的关键字,都可以当标识符使用

四、字符串输出

1.基本语法

(1)字符串拼接法:println(name+" " +age)

  (2)类似C语言的printf,通过%传值。printf("name=%s age=%d \n  ",name ,age)

  (3)字符串模板(插值字符串):通过$获取变量值printf(s"祝${name}的${age}生日快乐")

插入字符串(多行):使用''' .....''' 三个上引号包围多行字符串,在每一行前添加竖线“|”可实现以竖线为开头进行对其。其字符串输出的内容与编写时一致。

Scala的数据类型:

注意:表中列出的数据类型都是对象,也就是说scala没有java中的原生类型。在scala是可以对数字等基础类型调用方法的

整型字面量

整型字面量用于 Int 类型,如果表示 Long,可以在数字后面添加 L 或者小写 l 作为后缀。
示例:val i :Int = 20
示例:val i :Long = 50l

浮点型字面量

如果浮点数后面有f或者F后缀时,表示这是一个Float类型否则就是一个Double类型的。实例如下
示例:val i :Float = 50.03f
示例:val i :Double = 50.003

布尔型字面量Boolean

布尔型字面量有 true 和 false。

字符字面量

在 Scala 字符变量使用单引号 ' 来定义

字符串字面量

在 Scala 字符串字面量使用双引号 " 来定义

多行字符串的表示方法

多行字符串用三个双引号来表示分隔符,格式为:""" ... """。

例:

val sql = s"""|select *|from| student|where| name = ${name}|and| age > ${age}|""".stripMarginprintln(sql)

运行结果:

Null 值

空值是 scala.Null 类型。

Scala.Null和scala.Nothing是用统一的方式处理Scala面向对象类型系统的某些"边界情况"的特殊类型。

Null类是null引用对象的类型,它是每个引用类(继承自AnyRef的类)的子类。Null不兼容值类型。

转义字符:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/449362.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【课程作业_01】国科大2023模式识别与机器学习实践作业

国科大2023模式识别与机器学习实践作业 作业内容 从四类方法中选三类方法,从选定的每类方法中 ,各选一种具体的方法,从给定的数据集中选一 个数据集(MNIST,CIFAR-10,电信用户流失数据集 )对这…

【Springcloud篇】学习笔记五(十章):Gateway网关

第十章_Gateway新一代网关 1.Gateway简介 1.1官网 上一代zuul 1.X:https://github.com/Netflix/zuul/wiki 当前gateway:https://cloud.spring.io/spring-cloud-static/spring-cloud-gateway/2.2.1.RELEASE/reference/html/ 1.2是什么 SpringCloud …

MacOS安装JDK+Maven+Idea插件+nvm等

Java安装环境(MacOS)JDKMavenIdea插件nvm等 背景:新机安装开发环境发现需要找很多文章,,,,这里一篇文章安装所有环境 文章目录 Java安装环境(MacOS)JDKMavenIdea插件nvm等一、安装JDK①:下载②:…

【Qt5小项目】接金币小游戏

代码量在250行左右, 需要源码的可以私信我。

ubuntu20.04安装sumo

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 有问题,请大家指出,争取使方法更完善。这只是ubuntu安装sumo的一种方法。一、注意事项1、首先明确你的ubuntu的用户名是什么 二、sumo安装1.…

数据库笔记

文章目录 数据库概述基本概念存储过程完整性约束范式FAQ 分布式锁RedisMySQLZooKeeper 非关系型数据库Redis数据结构限流内存淘汰机制LRU 最近最少使用LFU 最近经常使用 过期策略 关系型数据库Generic SQL数据类型索引负面影响原则类型结构FAQ 事务隔离级别并发导致的问题ACID特…

Java常用

文章目录 基础基础数据类型内部类Java IOIO多路复用重要概念 Channel **通道**重要概念 Buffer **数据缓存区**重要概念 Selector **选择器** 关键字final 元注解常用接口异常处理ErrorException JVM与虚拟机JVM内存模型本地方法栈虚拟机栈 Stack堆 Heap方法区 Method Area (JD…

【python】英语单词文本处理

文章目录 前言一、环境实验所需的库终端指令 二、实现过程Version 1 起源Version 2 listVersion 3 arrayVersion 4 结构化数组Version 5 区分单元且打乱顺序Version 6 可视化 三、txt文件 前言 缘起自懒得考小孩儿单词,最终效果如图: 本文记录了英语单词…

Loadbalancer如何优雅分担服务负荷

欢迎来到我的博客,代码的世界里,每一行都是一个故事 Loadbalancer如何优雅分担服务负荷 前言Loadbalancer基础:数字世界的分配大师1. 分发请求:2. 健康检查:3. 会话保持:4. 可伸缩性:5. 负载均衡…

京东物流基于 StarRocks 的数据分析平台建设

作者:京东物流 数据专家 刘敬斌 小编导读: 京东集团 2007 年开始自建物流,2017 年 4 月正式成立京东物流集团,截至目前,京东物流已经构建了一套全面的智能物流系统,实现服务自动化、运营数字化及决策智能化…

如何写好论文——(14)写作时如何定义和描述研究目标

当我们有了一个具体的细化的研究目标之后,我们需要把它清晰准备描述给我们的读者,并用它来指导我们的研究活动。 一、有方向 我们所选择的具体的研究目标一定要有明确的目标指向,那就是我们的长远目标。 二、有边界 我们要明确自己的研究…

react 之 zustand

zustand可以说是redux的平替 官网地址:https://zustand-demo.pmnd.rs/ 1.安装 npm i zustand2.基础使用 // zustand import { create } from zustand// 1. 创建store // 语法容易出错 // 1. 函数参数必须返回一个对象 对象内部编写状态数据和方法 // 2. set是用来…