91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

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

北川| 揭阳市| 长乐市| 靖西县| 犍为县| 云梦县| 博爱县| 呼伦贝尔市| 琼海市| 阳城县| 改则县| 滨州市| 华宁县| 民勤县| 东阳市| 竹山县| 安多县| 石林| 阳东县| 乌鲁木齐县| 海门市| 南雄市| 蓬安县| 资阳市| 屏山县| 潜江市| 淮滨县| 新建县| 肇州县| 洮南市| 内乡县| 铜山县| 滦南县| 金阳县| 闽清县| 关岭| 南澳县| 兴和县| 会同县| 阳春市| 阿克苏市|