Scala快学笔记(三)
一 ,文件操作:
1,读取行:val source=Source.fromFile("fileName","utf-8) 形成一个字符串:source.mkString 从网络中读取:val source=Source.fromURL("http://www.baidu.com","utf-8")
2,读取二进制文件,写入文本文件,访问目录都需要引入java.文件处理方法
3,序列化:需要序列化的场景:由于序列化的使用会影响系统的性能,因此如果能不使用就尽量不要使用。(class extends Serializable)
- 需要通过网络来发送对象,或将对象的状态需要被持久化保存到数据库或文件中
4,反序列化:将流转为对象
import collection.mutable.ArrayBuffer
import java.io.{ObjectInputStream,ObjectOutputStream,FileInputStream,FileOutputStream}
class Person(var name:String) extends Serializable{
val friends=new ArrayBuffer[Person]()
def addFirend(p:Person):ArrayBuffer[Person]={
friends += p
}
override def toString()={
var str="My name:"+name+"and my firends name is"
friends.foreach(str +=_.name+",")
str
}
}
object seriTest extends App{
val p=new Person("1")
val f1=new Person("2")
val f2=new Person("3")
p.addFirend(f1)
p.addFirend(f2)
print(p)
val out=new ObjectOutputStream(new FileOutputStream("test.txt"))
out.writeObject(p)
out.close()
val in =new ObjectInputStream(new FileInputStream("test.txt"))
val p1=in.readObject.asInstanceOf[Person]
println(p)
}
输入流与输出流:
InputStream(字节输入流)和Reader(字符输入流)通俗的理解都是读(read)的。
OutputStream(字节输出流)和Writer(字符输出流)通俗的理解都是写(writer)的。
在整个Java.io包中最重要的就是5个类和一个接口。5个类指的是File、OutputStream、InputStream、Writer、Reader;一个接口指的是Serializable.掌握了这些IO的核心操作那么对于Java中的IO体系也就有了一个初步的认识了
5,正则表达式
https://deerchao.net/tutorials/regex/regex.htm#getstarted
几个正则表达式应用题:
//9.6
import scala.io.Source
object regexTest extends App{
val path="/home/hadoop/people.txt"
val file=Source.fromFile(path)
val pattern="\\w+\\s+\"".r
pattern.findAllIn(file).foreach(println(_))
}
//9.7 非浮点数
object regexTest2 extends App{
val path="/home/hadoop/people.txt"
val file=Source.fromFile(path)
val pattern="""[^((\d+.)?\d+)^\s+] """.r//非浮点数非空格
pattern.findAllIn(file).foreach(println(_))
}
//9.8 寻找 < img src="">
object regexTest3 extends App{
val path="http://www.hao123.com"
val file=Source.fromURL(path).mkString
val pattern="""<img[^>]+(src\s*=\s*"[^>^"]+")[^>]*>""".r
for (str <- pattern.findAllIn(file)) println(str)
}
6,特质
Java:类只能扩展一个超类,它可以实现任意数量的接口,但接口只能有抽象方法,不能包含字段
为什么接口中的常量必须使用public static final修饰
public: 使接口的实现类可以使用这个常量
static:static修饰就表示它属于类的,随的类的加载而存在的,如果是非static的话,
就表示属于对象的,只有建立对象时才有它,而接口是不能建立对象的,所以
接口的常量必须定义为static
final:final修饰就是保证接口定义的常量不能被实现类去修改,如果没有final的话,
由子类随意去修改的话,接口建立这个常量就没有意义了。
特质,不支持多重继承,因为多重继承会产生菱形继承问题,可以理解为一种缺少构造器参数的类,拥有具体或抽象的字段和方法,或超类
Scala快学笔记(三)的更多相关文章
- Scala快学笔记(二)
一,基本概念 1,映射 Map与HashMap与TreeMap,SotredMap等区别: 1.HashMap键无序,它根据键的HashCode值存储数据,根据键可以直接获取它的值,具有很快的访问速度 ...
- Scala快学笔记(一)
一,基本概念: 1,Scala是一种基于JVM的面向对象和函数式编程语言 2,基本类型:数值类型 ->:Byte,Short,Int,Long,Float,Double和布尔类型:Boolean ...
- Scala入门学习笔记三--数组使用
前言 本篇主要讲Scala的Array.BufferArray.List,更多教程请参考:Scala教程 本篇知识点概括 若长度固定则使用Array,若长度可能有 变化则使用ArrayBuffer 提 ...
- [Scala] 快学Scala A1L1
基础 1.1 声明值和变量 在Scala中,鼓励使用val; 不需要给出值或变量的类型,这个信息可以从初始化表达式推断出来.在必要的时候,可以指定类型. 在Scala中,仅当同一行代码中存在多条语句时 ...
- [Scala] 快学Scala A3L3
Actor 通过尽可能避免锁和共享状态,actor使得我们能够容易地设计出正确.没有死锁或争用状况的程序. Scala类库提供了一个actor模型的简单实现.AKKA是更高级的actor类库. 19. ...
- [Scala] 快学Scala A2L2
集合 13.1 集合的三大类 所有的集合都扩展Iterable特质.集合的三大集合为Seq, Set, Map Seq是一个有先后次序的值的序列,比如数组或列表.IndexSeq允许我们通过整型下表快 ...
- 快学Scala-第三章 数组相关操作
知识点: 1.定长数组 Array val nums = new Array[Int](10) //10个整数的数组,所有元素初始化为0 val a = new Array[String](10) / ...
- Scala学习教程笔记三之函数式编程、集合操作、模式匹配、类型参数、隐式转换、Actor、
1:Scala和Java的对比: 1.1:Scala中的函数是Java中完全没有的概念.因为Java是完全面向对象的编程语言,没有任何面向过程编程语言的特性,因此Java中的一等公民是类和对象,而且只 ...
- 快学Scala习题解答—第一章 基础
1 简介 近期对Scala比较感兴趣,买了本<快学Scala>,感觉不错.比<Programming Scala:Tackle Multi-Core Complexity on th ...
随机推荐
- Linux内核线程之深入浅出【转】
转自:http://blog.csdn.net/yiyeguzhou100/article/details/53126626 [-] 线程和进程的差别 线程的分类 1 内核线程 2 轻 ...
- python 微博评论获取的时候日期格式化
# -*- coding: utf-8 -*- # @Time : 2018/03/05 10:57 # @Author : cxa # @File : testDataTime.py # @Soft ...
- js面向对象编程(三)非构造函数的继承(转载)
Javascript面向对象编程(三):非构造函数的继承 今天是最后一个部分,介绍不使用构造函数实现"继承". 一.什么是"非构造函数"的继承? 比如,现在有一 ...
- win32 sdk列表视图控件(ListCtrl或ListView)资料整理
列表视图控件是一种非常常用的控件,在需要以报表形式显示数据时,列表控件通常是最好的选择,许多专用的数据报表控件,也是在它的基础上派生而来.与树视图类似,列表控件可以由多个子项目组成,可以设置为Icon ...
- Selenium2+python自动化65-js定位几种方法总结【转载】
前言 本篇总结了几种js常用的定位元素方法,并用js点击按钮,对input输入框输入文本 一.以下总结了5种js定位的方法 除了id是定位到的是单个element元素对象,其它的都是elements返 ...
- python-函数(命名空间、作用域、闭包)
一.命名空间 全局命名空间 局部命名空间 内置命名空间 *内置命名空间中存放了python解释器为我们提供的名字:input,print,str,list,tuple...它们都是我们熟悉的,拿过来就 ...
- (一)shell基础
(1)shell作用: 1)自动化批量系统初始化程序(软件安装,时区设置,安全策略) 2)自动化批量软件部署程序(LNMP,LAMP,LNTM) 3)管理应用程序(kvm,集群管理扩容) 4)日志分析 ...
- F - Oil Deposits 【地图型BFS+联通性】
The GeoSurvComp geologic survey company is responsible for detecting underground oil deposits. GeoSu ...
- Linux内核ROP姿势详解(二)
/* 很棒的文章,在freebuf上发现了这篇文章上部分的翻译,但作者貌似弃坑了,顺手把下半部分也翻译了,原文见文尾链接 --by JDchen */ 介绍 在文章第一部分,我们演示了如何找到有用的R ...
- Linux命令之fdisk
fdisk fdisk [选项] <disk> 改变分区表 fdisk [选项] –l <disk> 列出所有分区表 fdisk –s <partition(分区编号 ...