当前位置: 首页 > news >正文

苏州网站建设网站建设西安网站建设排名

苏州网站建设网站建设,西安网站建设排名,最便宜的网站建设公司,前端培训机构Scala迭代器模式处理数据 scala中创建集合需要内存,集合与集合之间的转换时,每次转换生成新的集合时,新的集合也需要内存。如果有一个非常大的初始集合,需要经过多次转换,每次转换都生成一个新的集合,才能…

Scala迭代器模式处理数据

scala中创建集合需要内存,集合与集合之间的转换时,每次转换生成新的集合时,新的集合也需要内存。如果有一个非常大的初始集合,需要经过多次转换,每次转换都生成一个新的集合,才能得到最终的结果,那么这时,在集合转换过程中内存开销非常大。Scala迭代器模式处理数据,很好的解决了内存占用大的问题。

Scala迭代器模式处理数据每次将集合的转换转变成了迭代器之间的转换,迭代器是不需要占用内存存储的,迭代器只是一个指针,指向了最初的原始数据,这样,数据处理过程中内存占用非常小。

迭代器模式处理示例:

//非迭代器模式处理,浪费内存
val list1 = List[String]("hello java","hello python","hello scala")
val list2 = list1.flatMap(one=>{one.split(" ")})
val list3 = list2.map(one=>{one+"#"})
list3.foreach(println)println("***********************")//迭代器模式处理,内存小
val list = List[String]("hello java","hello python","hello scala")
val iter1 = list.iterator
val iter2 = iter1.flatMap(one=>{one.split(" ")})
val iter3 = iter2.map(one=>{one+"#"})
while(iter3.hasNext){val one = iter3.next()println(one)}

Trait 特质特性

1、概念理解

Scala Trait(特质) 相当于java的接口,实际上它比接口还功能强大。与接口不同的是,它还可以定义属性和方法的实现。

一般情况下Scala的类可以继承多个Trait,从结果来看就是实现了多重继承。第一个关键字使用extends,之后使用with。

Trait(特质)定义的方法与类类似,但它使用的关键字是trait。

2、举例:trait中带属性带方法实现

注意:

继承的多个trait中如果有同名的方法和属性,必须使用“override”重新定义。

2、trait中不可以传参数

trait Read {val readType = "Read"val gender = "m"def read(name:String){println(name+" is reading")}
}trait Listen {val listenType = "Listen"val gender = "m"def listen(name:String){println(name + " is listenning")}
}class Person() extends Read with Listen {override val gender = "f"
}object test {def main(args: Array[String]): Unit = {val person = new Person()person.read("lisi")person.listen("zhangsan")println(person.listenType)println(person.readType)println(person.gender)}}

3、举例:trait中带方法不实现

1.object Lesson_Trait2 {
2.  def main(args: Array[String]): Unit = {
3.    val p1 = new Point(1,2)
4.    val p2 = new Point(1,3)
5.    println(p1.isEqule(p2))
6.    println(p1.isNotEqule(p2))
7.  }
8.}
9.
10.trait Equle{
11.  def isEqule(x:Any) :Boolean 
12.  def isNotEqule(x : Any) = {
13.     !isEqule(x)
14.  }
15.}
16.
17.class Point(x:Int, y:Int) extends Equle {
18.  val xx = x
19.  val yy = y
20.
21.  def isEqule(p:Any) = {
22.    p.isInstanceOf[Point] && p.asInstanceOf[Point].xx==xx
23.  }
24.
25.}

http://www.khdw.cn/news/12756.html

相关文章:

  • 网站是通过超链接百度seo推广计划类型包括
  • 六枝做网站如何进行搜索引擎的优化
  • 网站seo推广公司靠谱吗长尾关键词排名工具
  • 网站优化师负责干什么广州优化防控措施
  • 乐清建设网站公司爱链网中可以进行链接买卖
  • 做化妆品的一些网站企业推广是做什么的
  • 设计网站大全有哪些寰宇seo
  • 高手做网站怎么开发自己的网站
  • 台州做网站最好的搜索引擎网站大全
  • 怎么做跑腿网站网站排名优化外包公司
  • 网站建设委托外包协议书搜索引擎市场份额2023
  • 不包括seo01网站
  • 昆明网站建设价目表seo蜘蛛屯
  • 过年做哪个网站致富全球搜索引擎入口
  • 付费 视频 网站 怎么做建站系统cms
  • 元氏县城有做网站广告的吗自媒体seo是什么意思
  • 加国无忧51工作网深圳seo招聘
  • 最好记得网站域名交友网站有哪些
  • 门户网站做公众号的好处免费b2b信息发布网站
  • 无锡企业网络诈骗青岛推广优化
  • 潍坊建筑公司排名南宁seo排名优化
  • 网站单页模板怎么安装网络销售是什么工作内容
  • 做网站用什么软件好四川seo推广方案
  • 网站开发与维护是做什么工作预防电信网络诈骗
  • 旅游交友的网站建设营销软文推广平台
  • 淄博市建设监理协会网站小程序制作费用一览表
  • 织梦做网站简单吗百度推广好做吗
  • 网页设计师 培训珠海百度搜索排名优化
  • 阿里巴巴外贸平台中文东莞网站推广及优化
  • 网站建设后的团队总结今日新闻头条新闻最新