Scala语法1
main方法和def 函数
package scala_01
/**
* main方法只能放在object中运行
* object 修饰的类 就相当于静态类 也相当于代码加载到虚拟机中的 “类对象”
* 类中的方法及属性 相当于自动加上了 static
* 可以直接通过 “类对象”(类名)直接进行调用
* 单例模式
*/
object ScalaDemo1 {
/**
* Scala中的main方法
* 在scala中方法不可以用static修饰
* def 定义一个函数的关键字
* main 方法名
* args: Array[String] 参数名:参数类型
* Unit 返回值类型 相当于java中的void
* {} 方法体
*/
def main(args: Array[String]): Unit = {
println("Hello World!~")
// 在scala中使用java中的类
val stu: StudentJava = new StudentJava(1,"zs",18)
println(stu.id)
println(stu.name)
println(stu.getAge)
println(stu getAge)
println(stu)
// 通过类名直接调用方法
ScalaDemo1.print()
println(ScalaDemo1.print())
ScalaDemo1.print2("hahah")
}
def print():String={
println("scala")
return "0"
}
def print2(s:String): Unit ={
println("scala2")
println(s)
}
}
/**
* 输出结果
* Hello World!~
* 1
* zs
* 18
* 18
* StudentJava{id=1, name='zs', age=18}
* scala
* scala
* 0
* scala2
* hahah
*/
变量,类型转换,字符串分割拼接
package scala_01
object ScalaDemo2 {
def main(args: Array[String]): Unit = {
/**
* 变量
* 可以用val 和 var修饰,定义的时候不需要指定类型
* 用val修饰的变量 不能进行修改 相当于常量
* 用var修饰的变量 可以进行修改
* 能使用val就用val
*/
val i = 100
var j = 200
println(i)
println(j)
j = 300
println(j)
/**
* 类型推断
*/
// 自动推断
val k = 100
// 手动加上类型 √
val kk: Int = 200
println(k + kk)
// Java中的类型转换
// Scala中的String就是Java中的String
val str1: String = "123"
println(Integer.valueOf(str1))
// Scala 中的类型转换
//只要数据符合要求就可以直接to+类型
// 隐式转换 动态增加方法
val str2: String = "321"
println(str2.toInt)
// 字符串分隔
val str3: String = "Hello,World"
println(str3.split(","))
// 字符串拼接
val builder: StringBuilder = new StringBuilder()
builder.append("a")
builder.append("pple")
println(builder)
// scala中更好的字符串拼接
val str4: String = "bana"
val str5: String = "na"
// s"$变量名" ,底层也是StringBuilder
println(s"$str4,$str5")
// java中不行
println("-" * 50)
}
}
/**
* 100
* 200
* 300
* 300
* 123
* 321
* [Ljava.lang.String;@45c8e616
* apple
* bana,na
* --------------------------------------------------
*/
文件读写和JDBC
package scala_01
import java.sql.DriverManager
import scala.io.{BufferedSource, Source}
object ScalaDemo3 {
def main(args: Array[String]): Unit = {
// 文件读写
val source: BufferedSource = Source.fromFile("scala/data/students.txt")
val it: Iterator[String] = source.getLines()
for (elem <- it) {
println(elem)
}
println("-"*50)
// 第一种简化方式
// Source.fromFile.getLines.for
for (elem <- Source.fromFile("scala/data/students.txt")
.getLines()) {
println(elem)
}
println("-"*50)
// 第二种简化
Source.fromFile("scala/data/students.txt")
.getLines()
.foreach(println)
// JDBC
Class.forName("com.mysql.jdbc.Driver")
val conn =
DriverManager.getConnection("jdbc:mysql://master:3306/student?useSSL=false", "root", "123456")
val statement = conn
.prepareStatement("select * from student where age=?")
statement.setString(1,"22")
val rs = statement.executeQuery()
while (rs.next()){
val name = rs.getString("name")
val age = rs.getString("age")
println(s"$name,$age")
}
conn.close()
}
}
面向对象编程
/**
* 面向对象编程
* 类中可以定义属性、方法、构造函数
*/
/**
* {}就是scala中类默认的构造函数
* id: String, name: String, age: Int 构造函数的参数
*/
class Student(id: String, name: String, age: Int) {
println("默认的构造函数")
val _id = id
val _name = name
val _age = age
var _clazz: String = _
// 重载构造方法 需要重新实现this方法
// 第一行代码必须调用默认的构造方法
def this(id: String, name: String, age: Int, clazz: String) {
// 调用默认的构造方法
this(id, name, age)
_clazz=clazz
println("重载构造方法")
}
// 重写了父类的toString方法
override def toString(): String = {
// 如果变量名以下划线开头 需要用花括号括起来
// 如果想调用变量的某个方法 也需要用花括号括起来
// return 可以省略 最后一行代码默认是返回的值
s"Student(_id=${_id}, _name=${_name}, _age=${_age},_clazz=${_clazz})"
}
}
object ScalaDemo4 {
def main(args: Array[String]): Unit = {
val stu: Student = new Student("1001", "zs", 18)
println(stu._id)
println(stu._name)
println(stu._age)
println(stu)
println("-" * 50)
val stu2: Student = new Student("001", "张三", 21, "文科一班")
println(stu2._id)
println(stu2._name)
println(stu2._clazz)
println(stu2)
}
}
/**
* 默认的构造函数
* 1001
* zs
* 18
* Student(_id=1001, _name=zs, _age=18,_clazz=null)
* --------------------------------------------------
* 默认的构造函数
* 重载构造方法
* 001
* 张三
* 文科一班
* Student(_id=001, _name=张三, _age=21,_clazz=文科一班)
*/
继承
object ScalaDemo5 {
def main(args: Array[String]): Unit = {
//这里A也可以使用B,A更加体现出多态
val b:A = new B("002","ls",22)
println(b)
}
}
class A(id:String,name:String){
println("A的构造方法")
val _id=id
val _name =name
override def toString = s"A(_id=${_id}, _name=${_name})"
}
/**
* 继承还是使用extends关键字
* 但是在继承就需要调用父类的构造方法
*/
class B(id:String,name:String,age:Int) extends A(id,name){
println("B中的构造方法")
val _age=age
override def toString = s"B(${_id}, ${_name}, ${_age})"
}
/**
A的构造方法
B中的构造方法
B(002, ls, 22)
*/
case类,最常用的
object ScalaCaseDemo6 {
def main(args: Array[String]): Unit = {
// 创建样例类的对象时 new关键字可以省略
val ss:Stu = Stu("0003","ww",21,"男","理科八班")
println(ss.id)
println(ss.name)
println(ss.age)
println(ss.gender)
println(ss.clazz)
// 样例类中的参数 就是该类的属性
// 默认以val修饰 如果想要重新赋值 则需要手动指定为var
ss.age=88
println(ss.age)
}
}
case class Stu(id:String,name:String,var age:Int,gender:String,clazz:String)
Scala语法1的更多相关文章
- scala语法在spark withScope上的应用
withSpout在spark中是用来做DAG可视化的,它在代码里的用法如下(以map为例,spark 2.0.0版本) def map[U: ClassTag](f: T => U): RDD ...
- scala语法解析(解码指环)
看惯了JAVA的语法,再看scala的语法,有的晦涩难懂.正好遇到一个介绍scala语法的文章,就直接截图留念.省的再临时抱佛脚了.
- 1.scala语法
对象的apply方法 (1)对象调用apply()方法,可省略成() (2)string对象的apply方法返回第n个字符 "hello"(4) //'o' if语句的返回值 ja ...
- Scala语法笔记
JAVA中,举例你S是一个字符串,那么s(i)就是该字符串的第i个字符(s.charAt(i)).Scala中使用apply的方法 JAVA与C++的?:操作符 等同于Scala的 if ( x &g ...
- Java和Scala语法比较
类型推断 挑逗指数: 四星 我们知道,Scala一向以强大的类型推断闻名于世.很多时候,我们无须关心Scala类型推断系统的存在,因为很多时候它推断的结果跟直觉是一致的. Java在2016 年也新增 ...
- Spark记录-Scala语法基础
参考:http://docs.scala-lang.org/cheatsheets/index.html.http://docs.scala-lang.org/.http://www.scala-la ...
- Scala 语法基础
一 简介 Scala 是一门多范式(multi-paradigm)的编程语言,设计初衷是要集成面向对象编程和函数式编程的各种特性.Scala 运行在Java虚拟机上,并兼容现有的Java程序.Scal ...
- Scala 语法(一)
(1)基本语法 变量 val var(可变变量): 数据类型 Byte,Char,Int,Short,Long,String(字符),Float,Double,Boolean(true,flase). ...
- scala语法
1:双重for循环(相当于j是i的内存循环):for (i <-0 to n; j <-10 to 20){ println(i);println(j)} 2:单层for循环:for (i ...
- Scala语法(二)
(1)类,对象 //定义类(属性.方法),实例化对象 class counter{ *//主构造器 class counter(name:String,mode:Int){ ... } 实例化:val ...
随机推荐
- JavaScript之 函数节流(Throttling) 与 防抖(Debounce)
Throttling:在监听鼠标移动事件.盒子滚动事件等使用节流技术能节省性能消耗 /** * 节流函数(每隔t执行一次) */ function Throttling(fn, t) { const ...
- Ubuntu安装盘的制作
准备工作 Ubuntu系统镜像 win32diskimager U盘(4G以上),对重要文件提前备份 制作 下载系统镜像 进入官网 我们下载的版本是18.04,不是20.04 在页面中,找到BitTo ...
- ApacheCN 计算机视觉译文集 20210212 更新
新增了六个教程: OpenCV 图像处理学习手册 零.前言 一.处理图像和视频文件 二.建立图像处理工具 三.校正和增强图像 四.处理色彩 五.视频图像处理 六.计算摄影 七.加速图像处理 Pytho ...
- MySQL 事务的隔离级别及锁操作的一点点演示
MySQL 版本:5.7 安装环境:MAC OS 一.测试数据 测试数据库:test:测试表:tt CREATE TABLE `tt` ( `id` int(11) DEFAULT NULL, `na ...
- 在Rainbond中实现数据库结构自动化升级
Rainbond 这款产品一直致力于打通企业应用交付的全流程,这个流程中不可或缺的一环是企业应用的不断升级.迭代.Rainbond 特有的能力,是可以将囊括多个服务组件的企业应用系统进行打包,并执行一 ...
- LockSupport、wait()、notify()
LockSupport 名词解释 LockSupport是一个在JUC包里的线程阻塞工具类,所有的方法都是静态方法,主要用途是让线程在任意位置阻塞,广泛应用在AQS和各种JUC的锁中. 代码 publ ...
- NSArray文件读写
1.NSArray数据写入到文件中 NSArray *arr = @[@"lnj", @"lmj", @"jjj", @"xcq& ...
- Docker安全及日志管理
Docker安全及日志管理 目录 Docker安全及日志管理 一.Docker容器与虚拟机的区别 1. 隔离与共享 2. 性能与损耗 3. 总结 二.Docker存在的安全问题 1. Docker自身 ...
- Ubuntu 16.04 更改系统语言为简体中文 #####避坑指南
大家跟着我的步骤一步一步来,肯定不会出现问题的 我这里说明两点,一是切换到管理员用户,二是更新网络源! 且待大家走一遍安装流程 一.安装时报错 原因:以访客的身份进入的会报错,改为管理员进入即可. p ...
- Solution -「CF 917D」Stranger Trees
\(\mathcal{Description}\) Link. 给定一棵包含 \(n\) 个点的有标号树,求与这棵树重合恰好 \(0,1,\cdots,n-1\) 条边的树的个数,对 \(10 ...