Spark记录-Scala类和对象】的更多相关文章

本章将介绍如何在Scala编程中使用类和对象.类是对象的蓝图(或叫模板).定义一个类后,可以使用关键字new来创建一个类的对象. 通过对象可以使用定义的类的所有功能. 下面的图通过一个包含成员变量(name 和 rollNo)和成员方法(setName()和setRollNo())的Student类的例子来演示类和对象.最后都是类的成员.类是一个模板的东西,而对象是真实存在的. 在下图中,Student是一个类,而具体学生:Harini, John, 和 Maria 是学生类的对象,这此对象有是…
//基类-Person class Person(val na: String, val ag: Int) { //属性 var name: String = na var age: Int = ag } //派生类-sz,继承基类属性 class sz(override val na:String,override val ag:Int,val se:String,val add:String) extends Person(na,ag){ //属性 var sex:String=se var…
scala类和对象 RDD中创建_sc和deps相比java更加的简洁. 在Spark的例如SparkContext.sqlSpark等全局成员在完成实例化. 在唯一实例的时候一般不会去使用伴生对象apply方法. 伴生类和伴生对象必须写在同一个文件之中.…
object func { def main(args:Array[String]):Unit={ //函数赋值给变量时, 必须在函数后面加上空格和下划线. def sayHello(name: String) { println("Hello, " + name) } val sayHelloFunc = sayHello _ sayHelloFunc("leo") //Scala定义匿名函数的语法规则: (参数名: 参数类型) => 函数体 val say…
1. 类和属性 1.1 如何控制构造函数字段的可见性 在Scala中: 如果一个字段被声明为var, Scala会为该字段生成getter和setter方法. 如果字段是val, Scala只生成getter方法. 如果一个字段没有var或者val的修饰符, Scala比较保守,不会生成getter和setter方法. 另外,var和val字段可以被private关键字修饰,这样可以防止生成getter和setter方法. 我们看一下测试代码: object Demo{ def main(arg…
Scala class: Scala 源文件中可以有很多类(class),这些类默认都是Public的,public是Scala的默认访问级别.在Scala中,声明一个未用priavate修饰的字段 var age,scala编译器会字自动帮我们生产一个私有字段和2个公有方法get和set ,这和C#的简易属性类似.例如: stu.age = 10 (此处的age是def age = (x$1: Int):Unit) println(stu.age) (此处的age是def age: Int)…
类简介 简介 类是对象的蓝图.一旦你定义了类,就可以用关键字new根据类的蓝图创建对象.在类的定义里,可以放置字段和方法,这些被笼统地称为成员.对于字段,不管是val还是var定义的,都是指向对象的变量.对于方法,用def定义,包含了可执行代码.字段保留了对象的状态或数据,而方法使用这些数据执行对象的运算工作.当类被实例化的时候,运行时环境会预留一些内存来保留对象的状态映像——即变量的内容. 示例 创建类示例: class SumAccumulator { var sum = 0 } 然后实例化…
1.scala shell命令 scala> :help All commands can be abbreviated, e.g., :he instead of :help. :edit <id>|<line> edit history :help [command] print this summary or command-specific help :history [num] show the history (optional num is commands t…
Scala函数 Scala有函数和方法. Scala方法是一个具有名称和签名的类的一部分. Scala中的函数是一个可以分配给变量的完整对象. 函数定义可以出现在源文件中的任何位置. 不带参数的函数 在Scala中定义函数,请使用def关键字,后跟方法名和方法体,如下所示. def hello() = {"Hello World!"} 等号=用作方法签名和方法体之间的分隔符. 我们可以使用hello()或hello调用此函数. object Main { def main(args:…
Scala的异常处理类似许多其他语言(如Java).它不是以正常方式返回值,方法可以通过抛出异常来终止. 但是,Scala实际上并没有检查异常. 当您想要处理异常时,要像Java一样使用try {...} catch {...}块,除了catch块使用匹配来识别和处理异常. 引发异常 抛出异常看起来与Java中的异常一样.创建一个异常对象,然后使用throw关键字将其抛出如下. throw new IllegalArgumentException Scala 捕获异常 Scala允许在单个块中t…
变量是保存存储值的内存位置的名称.这意味着当创建变量时,可以在内存中保留一些空间. 根据变量的数据类型,编译器分配内存并决定可以存储在预留内存中的内容.因此,通过为变量分配不同的数据类型,可以在这些变量中存储整数,小数或字符. 变量声明 Scala具有用于声明变量的不同语法.它们可以被定义为值,即常数或变量. 这里,myVar使用关键字var声明. 它是一个可以改变值的变量,这称为可变变量. 以下是使用var关键字定义变量的语法 - 语法 var myVar : String = "Foo&qu…
如果您熟悉Java语言语法和编程,那么学习Scala将会很容易.Scala和Java之间最大的句法差异在于行结束字符的分号(;) 是可选的. 当编写Scala程序时,它可以被定义为通过调用彼此的方法进行通信的对象的集合.现在我们简单地看一下类,对象,方法和实例变量的含义. 对象 - 对象有状态和行为.一个对象是类的一个实例.例如 - 狗有状态:颜色,名称,品种,它行为有:摇摆,吠叫和吃东西. 类 - 可以将类定义为描述与该类相关的行为/状态的模板/蓝图. 方法 - 一个方法基本上是一种行为.一个…
1.面向对象 Scala的类与java.C++的一些比起来更简洁,速度更快 对象:使用object关键字修饰的 类:使用class关键字修饰的new Person()实例对象 new类:类的实例(对象) 1.1.单例对象 (1)scala中没有静态方法和静态字段,没有static (2) java中,没有关键字修饰的方法,只能用new class()来修饰方法 (3)队友一个class来说,所有的方法和成员变量在市里被new出来之前都无法访问 (4)虽然在class中的定义main方法,可是并没…
1.hello world程序 object HelloWorld { def main(args: Array[String]) { println("Hello,World!") } } 注意 语句末尾的分号通常是可选的. 语句末尾的分号通常是可选的. 分号是表达式分隔符,它们是推断的. Scala将行的结尾视为表达式的结尾,除非它可以推断表达式继续到下一行. Scala程序处理从主方法开始,这是每个Scala程序的一个强制性部分. 主要方法未标记为静态. 主要方法是对自动实例化的…
Scala列表 Scala列表与数组非常相似,列表的所有元素都具有相同的类型,但有两个重要的区别. 首先,列表是不可变的,列表的元素不能通过赋值来更改. 其次,列表表示一个链表,而数组是平的. 具有类型T的元素的列表的类型被写为List[T]. 尝试以下示例,这里列出了为各种数据类型定义的列表. // List of Strings val fruit: List[String] = List("apples", "oranges", "pears&quo…
Scala多线程 多线程是同时执行多个线程的过程. 它允许您独立执行多个操作.可以通过使用多线程来实现多任务.线程是轻量级的子进程,占用较少的内存.多线程用于在Scala中开发并发应用程序. Scala不提供用于创建线程的任何单独的库.如果您熟悉Java的多线程概念,那么将会了解到它与Scala语言本身的语法相似. 可以通过扩展Thread类或Runnable接口来创建线程.两者都提供了运行方法来提供具体的实现. Scala线程生命周期 线程生命周期是线程开始和终止的时间跨度.它有各种各样的阶段…
Scala字符串 在Scala中的字符串和Java中的一样,字符串是一个不可变的对象,也就是一个不能修改的对象.可以修改的对象,如数组,称为可变对象.字符串是非常有用的对象,在本节的最后部分,我们将介绍java.lang.String类的一些重要方法. 1.创建一个字符串 以下是创建一个字符串的代码 - var greeting = "Hello world!"; // 或者 var greeting:String = "Hello world!"; Scala 每…
Scala与Java具有相同的数据类型,具有相同的内存占用和精度.以下是提供Scala中可用的所有数据类型的详细信息的表格: 序号 数据类型 说明 1 Byte 8位有符号值,范围从-128至127 2 Short 16位有符号值,范围从-32768至32767 3 Int 32位有符号值,范围从-2147483648至2147483647 4 Long 64位有符号值,范围从-9223372036854775808至9223372036854775807 5 Float 32位IEEE 754…
Scala是可扩展语言的缩写,是一种混合功能编程语言. 它由Martin Odersky创建. Scala顺利整合面向对象和函数式语言的功能. Scala被编译后在Java虚拟机上运行. 许多现有公司依靠Java进行关键业务应用转向或正在转向Scala,以提高其开发生产力,应用程序可扩展性和整体可靠性. 在这里,我们提出了一些要点,说明为什么Scala成为应用程序开发人员的首选. Scala是面向对象语言Scala是一种纯粹的面向对象语言,每一个值都是一个对象. 对象的类型和行为由类和特征描述,…
1.属性的定义 编写一个PersonS类,并在其中定义一些属性,通过PersonS.scala 编译后的情况查看,可以知道不同修饰符修饰的属性分别会生成什么方法(set,get) package com.jason.qianfeng class Persons { //val修饰的属性系统自动生成get方法 val id: String = "1234" //var 修饰的属性系统会自动生成set 和 get 方法 var name:String = "" // p…
参考:http://docs.scala-lang.org/cheatsheets/index.html.http://docs.scala-lang.org/.http://www.scala-lang.org/api/2.10.4/#package 变量   var x = 5 变量 好val x = 5不好x=6 不变 var x: Double = 5 显式类型 功能   好def f(x: Int) = { x*x }不好def f(x: Int) { x*x } 定义函数隐藏错误:无…
Scala try-catch语句 Scala提供try和catch块来处理异常.try块用于包含可疑代码.catch块用于处理try块中发生的异常.可以根据需要在程序中有任意数量的try...catch块. Scala try catch示例1 在下面的程序中,我们将可疑代码封装在try块中. 在try块之后使用了一个catch处理程序来捕获异常.如果发生任何异常,catch处理程序将处理它,程序将不会异常终止. class ExceptionExample{ def divide(a:Int…
Scala模式匹配 模式匹配是Scala函数值和闭包后第二大应用功能.Scala为模式匹配提供了极大的支持,处理消息. 模式匹配包括一系列备选项,每个替代项以关键字大小写为单位.每个替代方案包括一个模式和一个或多个表达式,如果模式匹配,将会进行评估计算.箭头符号=>将模式与表达式分离. 尝试以下示例程序,它显示匹配的整数值. 示例 object Demo { def main(args: Array[String]) { println(matchTest(3)) } def matchTest…
Scala提供了一种数据结构叫作数组,数组是一种存储了相同类型元素的固定大小顺序集合.数组用于存储数据集合,但将数组视为相同类型变量的集合通常更为有用. 可以声明一个数组变量,例如:numbers,使用numbers[0],numbers[1]和...,numbers[99]来表示单个变量,而不是分别地声明每个变量,例如number0,number1,...等变量. 本教程介绍如何使用索引变量声明数组变量,创建数组和使用数组.数组的第一个元素的索引是数字0,最后一个元素的索引是元素的总数减去1.…
函数声明 Scala函数声明具有以下形式 - def functionName ([list of parameters]) : [return type] Scala 如果不使用等号和方法体,则隐式声明抽象(abstract)方法. 函数定义 Scala函数定义具有以下形式 - 语法 def functionName ([list of parameters]) : [return type] = { function body return [expr] } Scala 这里,返回类型可以是…
import scala.util.control._ object learnning { def main(args:Array[String]):Unit={ val n:Int=10 println("第"+n+"个月兔子总数为"+fun(n)) val n1:Int=1 val n2:Int=100 var count:Int=0 //统计素数个数 for(i:Int<-n1 until n2){ if(isPrime(i)){ count=coun…
import Array._ import scala.collection.mutable.Set object DataStructure { def main(args:Array[String]):Unit={ //数组 var z:Array[String] = new Array[String](3); var z1 = new Array[String](3); z(0)="hello"; z1(0)="world"; var z2 = Array(&…
Scala条件运算符 Scala条件运算符在下表中列出. 运算符 操作 描述 && 与 运算符左侧和右侧的值为true.仅当左侧为真时,右侧才被计算. || 或 左侧或右侧的至少一个值为true.仅当左边为假时才计算右侧. > 大于 左侧的值大于右侧的值. >= 大于或等于 左侧的值大于或等于右侧的值. < 少于 左侧的值小于右侧的值. <= 小于或等于左侧的值小于或等于右侧的值. == 等于 左侧的值与右侧的值相同. != 不等于 左侧的值与右侧的值不同. 注意…
Scala while循环语句 当给定条件为真时,while循环重复一个语句或一组语句.它在执行循环体之前测试条件状态. 只要给定的条件为真,while循环语句重复执行目标语句. object Demo { def main(args: Array[String]) { // Local variable declaration: var a = 10; // while loop execution while( a < 20 ){ println( "Value of a: "…
object learn { def main(args:Array[String]):Unit={ println("请输入两个数字:") var a:Int=Console.readLine().toInt var n:Int=Console.readLine().toInt println(expressed(a,n)+add(a,n)); val n1:Int = 100; compNumber(n1); println("请输入三个数字") var n2:…