Scala基本语法

news/2024/11/28 17:53:06/

1.注释

Scala注释使用和Java完全一样。

注释是一个程序员必须要具有的良好编程习惯。

将自己的思想通过注释先整理出来,再用代码去体现。

基本语法

单行注释://

多行注释:/* */

文档注释:  /**  *  */

2.变量和常量

基本语法  

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

var i:Int = 10  

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

val j:Int = 20  

注意:能用常量的地方不用变量 

/*变量的命名规则:1、必须是大小写字母、数字、下划线构成2、不能以数字开头3、不能是关键字
*/object Demo02Base {var i=10i=200 //i可以进行重新赋值,但是不能改变数据类型val ii=11 //常量,不能改变值}

 注:类型可以省略,会自动匹配。

在scala没有基本数据类型,全是引用数据类型

在scala中,如果一个val变量指向一个容器,容器中的元素可以改变,这里指的是指向不变

 规则:

(1)声明变量时,类型可以省略,编译器自动推导,即类型推导

(2)类型确定后,就不能修改,说明Scala是强数据(静态数据)类型语言。

(3)变量声明时,必须要有初始值

(4)在声明/定义一个变量时,可以使用var或者val来修饰,var修饰的变量可改变,val修饰的变量不可改。

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

 3.Scala基本数据类型

Scala中一切数据都是对象,都是Any的子类

Scala中数据类型分为两大类,数值类型(AnyVal)、引用类型(AnyRef),不管是值类型还是引用类型都是对象

Scala数据类型任然遵守,低精度的值类型向高精度值类型,自动转换(隐式转换)

Scala中的String是对Java中的String增强。

Unit:对应Java中的void,用于方法返回值的位置,表示方法没有返回值。Unit是一个数据类型,只有一个对象就是()。Void不是数据类型,只是一个关键字

Null是一个类型,只有一个对象就是null。它是所有引用类型(AnyRef)的子类

Nothing是所有数据类型的子类,主要用在一个函数没有明确返回值时使用,因为这样我们可以把抛出的返回值,返回给任何的变量或者函数

AnyVal的八种数据类型:Byte,Int,Short,Long,Float,Double,Boolean,Char 

package com.bigdata.scalaobject Demo02Base {def main(args: Array[String]): Unit = {val byte: Byte = 10val short: Short = 100val int = 100 //默认为Int类型val long: Long = int //将精度较小的数据类型可以直接转换为精度较大的println(long)val float: Float = 1.23F //必须加Fval double: Double = 1.23 //默认为Double类型val char='a'println(char.toInt) //将char类型转换为Int型val boolean1:Boolean=true}}

注:scala严格区分单双引号,Char的精度小于Int类型

类型转换

基本说明

(1)自动提升原则:有多种类型的数据混合运算时,系统首先自动将所有数据转换成精度大的那种数据类型,然后再进行计算。

(2)把精度大的数值类型赋值给精度小的数值类型时,就会报错,反之就会进行自动类型转换。

(3)(byte,short)和char之间不会相互自动转换。

(4)byte,short,char他们三者可以计算,在计算时首先转换为int类型。

(5)boolean无法和其他类型转化

 

 强制类型转换直接使用.to数据类型方式,如  long.toInt

字符串类型

scala中的字符串类型来源于java中,但是做了加强和改进

package com.bigdata.scalaobject Demo02Base {def main(args: Array[String]): Unit = {//字符串类型转换val s1:String="123"println(s1.toInt) //toInt转换类型这类操作是Scala独有的,实际上是通过隐式转换加上去的println(s1.toDouble) // 隐式转换 就是动态给对象增加方法println(s1.toFloat)//字符串常见操作val s2:String="123,ffsdas,ddwfe"println(s2.toLowerCase())println(s2.toUpperCase()) //转大小写println(s2.substring(3,7)) //按照指定位置截取// Array[String] : 表示Scala中的字符串数组 相当于Java中的 String [] splitsval strings:Array[String] = s2.split(",")println(strings(1)) //java中通过[]传入下标,scala中通过()传如下标for (elem <- strings) { //增强for循环println(elem)}//String类型在Scala中比较常用的特有的方法strings.foreach(println) //以函数思想打印println(s2.head) //取头println(s2.tail) //取尾println(s2.take(3)) //取前三个println(s2.length)println(s2.size) //长度,大小println(s2.sorted) //排序println(s2.isEmpty) //判断是否为空}
}

格式化

package com.bigdata.scalaobject Demo02Base {def main(args: Array[String]): Unit = {// 格式化字符串:需要将字符串按照固定的格式进行输出// 例如:9 9 乘法表中每一个表达式都是,数 * 数 = 数 这样的格式printf("%d * %d = %d\n", 9, 9, 81) // 9 * 9 = 81 类似c语言// 还可以通过引用变量的方式进行传值val num01: Int = 9val num02: Int = 9val num03: Int = 81val _num04: Int = 81println(s"$num01 * $num02 = $num03")println(s"$num01 * $num02 = ${_num04}") // 如果需要引用的变量名以下划线开头,则需要用花括号括起来// 如果字符串需要换行,例如写SQL的时候,则可以使用""""""val sqlStr: String = "select clazz,count(*) as cnt from student group by clazz"val sqlStr2: String ="""|select clazz|       ,count(*) as cnt|from student|group by clazz|""".stripMargin // 适合写SQLprintln(sqlStr)println(sqlStr2)}}

4.Scala运算符

算数运算符

注:在除运算中,如果俩个数据类型均为整数类型,则返回的是整数类型 

关系运算符

 注:在判断字符串时,是按照一个一个字符进行比较的

在Scala中==更加类似于Java中的equals,比较的是值,eq比较的是地址值,类似于java中的==

位运算符 

& | ! >>  << ~

逻辑运算符

 


http://www.ppmy.cn/news/109744.html

相关文章

EclipseCDT远程交叉编译远程单步调试基于makefile例程(实测有效)

文章目录 前言&#xff1a;1. 新建工程2. 远程编译环境配置2.1 下载sshfs并挂载目录2.2 Debug配置2.3安装EclipseCDT的远程插件2.4 拷贝gdbserver 3. 调试总结: 前言&#xff1a; 之前写过一篇VSCode远程调试linux&#xff0c;当时是把程序以及代码通过远程的方式&#xff0c;…

有奖励!2023陕西省首台(套)重大技术装备产品项目申报条件、认定材料

本文整理了2023陕西省首台&#xff08;套&#xff09;重大技术装备产品项目申报条件&#xff0c;认定材料等相关内容&#xff0c;感兴趣的朋友快跟小编一起来看看吧&#xff01; 一、重点支持方向及领域 重点支持方向及领域&#xff1a;高档工业母机、电力装备、大型矿山和冶金…

Transformer 估算 101

本文主要介绍用于估算 transformer 类模型计算量需求和内存需求的相关数学方法。 引言 其实&#xff0c;很多有关 transformer 语言模型的一些基本且重要的信息都可以用很简单的方法估算出来。不幸的是&#xff0c;这些公式在 NLP 社区中鲜为人知。本文的目的是总结这些公式&…

pyest+appium实现APP自动化测试

目录 01、appium环境搭建 2、搭建pythonpytestappium环境 3、安装pycharm搭建项目编写脚本 4、执行测试 绵薄之力 01、appium环境搭建 安装nodejs http://nodejs.cn/ 为什么要安装nodejs&#xff1f; 因为appium这个工具的服务端是由nodejs语言开发的 安装jdk&#x…

python笔记16_实例练习_二手车折旧分析p1

python数据分析练习&#xff0c;具体数据不放出。 分析实践很简单。目的不是做完&#xff0c;而是讲清楚每一步的目的和连带的知识点&#xff08;所以才叫学习笔记&#xff09; 0.数据准备 原始数据格式&#xff1a;csv文件 原始数据结构&#xff1a; 数据格式 字段名 int…

日志 | 使用服务器

一篇稍有些散乱的个人记录。 文章目录 1 命令记录2 操作记录1. 添加用户clf2. 使用yum安装mysql3. 修改mysql密码4. 尝试在多个浏览器同时访问部署的blog 3 Bug记录1. 宝塔面板4042. pip freeze导出依赖&#xff0c;在服务器无法使用3. 安装insightface失败4. conda命令not fou…

大数据面试题目(第一部分)

您对“大数据”一词有什么了解&#xff1f; 当谈到"大数据"时&#xff0c;它是指处理和分析规模巨大、多样化且高速增长的数据集的技术和方法。这些数据通常无法在传统的数据库系统中轻松存储、处理和分析。大数据的特点包括数据量大、速度快、多样性高和价值密度低。…

代码随想录算法训练营第五十七天 | 回文

647. 回文子串 文档讲解&#xff1a;代码随想录 (programmercarl.com) 视频讲解&#xff1a;动态规划&#xff0c;字符串性质决定了DP数组的定义 | LeetCode&#xff1a;647.回文子串_哔哩哔哩_bilibili 状态&#xff1a;不会做。 思路 确定dp数组&#xff08;dp table&#xf…