中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Scala語言中如何結合demo和spark講實現鏈式計算

發布時間:2021-11-15 16:56:34 來源:億速云 閱讀:170 作者:柒染 欄目:大數據

Scala語言中如何結合demo和spark講實現鏈式計算,相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。

一,什么是鏈式計算

1,一般開發習慣把事情封裝到一個方法中;鏈式編程思想是把要做的事情封裝到block中,給外部提供一個返回這個block的方法

2,鏈式編程思想方法特點:方法的返回值必須是block,block的參數是需要操作的內容,block的返回值是返回這個block的方法的調用者

二,舉例說明

比如我們定義個case class Person

case class Person(private val parent: Person = null ,private val name: String = null , private var age: Int = 0 ) {
  def setName(newName: String) = new Person( this,newName, this.age )
  def setAge(newAge: Int) :this.type = {
    this.age = newAge;
    this
  }
  def introduce {parentIntroduce; println( s"Hello, my name is $name and I am $age years old." ) }
  def parentIntroduce { if(parent!=null)parent.introduce }
}

那么,我們可以執行下面操作:

Person(null,"kitty",45) .setName("Peter").setAge(41).setName("Peter1").setAge(21).introduce

執行的結果

Hello, my name is kitty and I am 45 years old.
Hello, my name is Peter and I am 41 years old.
Hello, my name is Peter1 and I am 21 years old.

其實,我這里是有個陷阱,比如我現在換一種順序調用(第一次調用setAge和setName互換),如下:

Person(null,"kitty",45) .setAge(41).setName("Peter").setName("Peter1").setAge(21).introduce

那么結果就會變成下面的樣子:

Hello, my name is kitty and I am 41 years old.
Hello, my name is Peter and I am 41 years old.
Hello, my name is Peter1 and I am 21 years old.

三,總結

之所以會出現上面兩種結果,是由于我們的setAge操作是執行之后返回的是對象本身,而setName操作又重新new 了一個對象。

由此,我們可以類比到RDD的操作。之前,群友問過這樣一個問題:

RDD.repartiton(12)

RDD的分區為啥不變成12呢?

實際上是由于RDD的所有轉換算子都是新生成了一個RDD,而不是將函數作用于自身。

其實,還有一種鏈式計算的實現方式是執行函數返回的是一個固定的類型,而不一定是調用者自身或者同父類的實現對象。比如,Dataset最終執行的實現函數的返回就是固定類型:RDD[InternalRow],而不是Dataset。

看完上述內容,你們掌握Scala語言中如何結合demo和spark講實現鏈式計算的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

繁峙县| 拜泉县| 安仁县| 河北区| 安远县| 静安区| 鞍山市| SHOW| 虞城县| 二连浩特市| 扶绥县| 荥阳市| 铁岭市| 万宁市| 大埔区| 黄梅县| 东乡族自治县| 基隆市| 奈曼旗| 德庆县| 边坝县| 新平| 辽宁省| 瑞昌市| 开封市| 临高县| 肥乡县| 汽车| 凉城县| 樟树市| 沛县| 巴林左旗| 鄯善县| 昌乐县| 巨野县| 武宁县| 宁夏| 湘西| 阳西县| 开鲁县| 泸州市|