內容簡介
高手昇級:可完全取代Java的Scala
內容簡介
資深大數據工程師開發經驗分享
循序漸進介紹Scala核心語法
透過實際操作用Scala進行應用開發
本書是作者在Scala 學習、工作實作及教育訓練過程中的心得體會和系統歸納,是學習Scala進行應用開發必備工具書。
本書涵蓋三大主要部分:
(1) Scala 語言基礎篇,主要介紹Scala 語言入門基礎知識、變數的定義、程式控制結構、Scala 集合。
(2) Scala 語言中級篇,主要介紹Scala 函數式程式設計、Scala 物件導向程式設計、Scala 模式比對。
(3) Scala 語言進階篇,主要介紹Scala 類型參數、自動轉型、Scala 平行處理程式設計、Scala 與Java 互動操作。
全書運用大量的實際案例來說明Scala 語言的應用,既能夠掌握核心語法,又能夠了解其背後的深層原理。
適用:Scala語言初學者、有興趣者,大數據開發人員、大數據框架運維工程師、軟體培訓機構以及電腦相關科系學生。
內容簡介
資深大數據工程師開發經驗分享
循序漸進介紹Scala核心語法
透過實際操作用Scala進行應用開發
本書是作者在Scala 學習、工作實作及教育訓練過程中的心得體會和系統歸納,是學習Scala進行應用開發必備工具書。
本書涵蓋三大主要部分:
(1) Scala 語言基礎篇,主要介紹Scala 語言入門基礎知識、變數的定義、程式控制結構、Scala 集合。
(2) Scala 語言中級篇,主要介紹Scala 函數式程式設計、Scala 物件導向程式設計、Scala 模式比對。
(3) Scala 語言進階篇,主要介紹Scala 類型參數、自動轉型、Scala 平行處理程式設計、Scala 與Java 互動操作。
全書運用大量的實際案例來說明Scala 語言的應用,既能夠掌握核心語法,又能夠了解其背後的深層原理。
適用:Scala語言初學者、有興趣者,大數據開發人員、大數據框架運維工程師、軟體培訓機構以及電腦相關科系學生。
作者簡介
周志湖、牛亞真
周志湖
電子科技大學電腦軟體與理論碩士,研究機器學習與模式識別,任職綠城房地產集團資訊管理部,擔任平台架構師、資料開發主管。對傳統資料倉、基於Hadoop和Spark的大資料倉架構有深入的研究。
牛亞真
中國科學院大學電腦資訊處理與檢索方向碩士,Hadoop大資料工程師,目前主要從事分散式環境下的資料分析、資料採擷相關工作。
周志湖
電子科技大學電腦軟體與理論碩士,研究機器學習與模式識別,任職綠城房地產集團資訊管理部,擔任平台架構師、資料開發主管。對傳統資料倉、基於Hadoop和Spark的大資料倉架構有深入的研究。
牛亞真
中國科學院大學電腦資訊處理與檢索方向碩士,Hadoop大資料工程師,目前主要從事分散式環境下的資料分析、資料採擷相關工作。
內容目錄
前言
Chapter01 Scala 入門
1.1 Scala 簡介
1.2 Scala 開發環境架設
1.3 Scala Hello World
1.4 Intellij IDEA 常用快捷鍵
1.5 互動式指令行使用
Chapter02 變數及基本資料型別
2.1 變數
2.2 基本資料型態
2.3 基本類型操作
2.4 運算子的優先順序
2.5 元組類型
2.6 符號類型
Chapter03 程式控制結構
3.1 if 敘述
3.2 while 循環敘述
3.3 for 循環敘述
Chapter04 集合
4.1 集合簡介
4.2 陣列
4.3 列表(List)
4.4 集合(Set)
4.5 對應(Map)
4.6 佇列(Queue)
4.7 堆疊(Stack)
Chapter05 函數
5.1 函數
5.2 值函數
5.3 高階函數
5.4 閉包
5.5 函數柯里化(Currying)
5.6 部分應用函數
5.7 偏函數
Chapter06 Scala 物件導向程式設計(上)
6.1 類別與物件
6.2 主建構函數
6.3 輔助建構函數
6.4 繼承與多形
6.5 成員存取控制
6.6 抽象類別
6.7 內部類別與內建物件
6.8 匿名類別
Chapter07 Scala 物件導向程式設計(下)
7.1 trait 簡介
7.2 trait 的使用
7.3 trait 與類別
7.4 多重繼承問題
7.5 本身類型
Chapter08 套件(package)
8.1 套件的定義
8.2 套件的使用和作用域
8.3 套件物件
8.4 import 進階特性
Chapter09 模式比對
9.1 模式比對簡介
9.2 模式符合的7 大類型
9.3 模式比對原理
9.4 正規表示法與模式比對
9.5 for 循環中的模式比對
9.6 模式比對與範例類別、範例物件
Chapter10 自動轉型
10.1 自動轉型簡介
10.2 自動轉型函數
10.3 隱式類別與隱式物件
10.4 隱式參數與隱式值
10.5 自動轉型規則與問題
Chapter11 型態參數
11.1 類別與類型
11.2 泛型
11.3 類型變數界定
11.4 視圖界定
11.5 上下文界定
11.6 多重界定
11.7 協變與逆變
11.8 進階類型
Chapter12 Scala 平行處理程式設計基礎
12.1 Scala 平行處理程式設計簡介
12.2 Actor
12.3 Typed Actor
12.4 Dispatcher
12.5 Router
12.6 容錯
Chapter13 Scala 與Java 的互動操作
13.1 Java 與Scala 集合互動操作
13.2 Scala 與Java 泛型互動操作
13.3 Scala trait 在Java 中的使用
13.4 Scala 與Java 異常處理互動操作
Chapter01 Scala 入門
1.1 Scala 簡介
1.2 Scala 開發環境架設
1.3 Scala Hello World
1.4 Intellij IDEA 常用快捷鍵
1.5 互動式指令行使用
Chapter02 變數及基本資料型別
2.1 變數
2.2 基本資料型態
2.3 基本類型操作
2.4 運算子的優先順序
2.5 元組類型
2.6 符號類型
Chapter03 程式控制結構
3.1 if 敘述
3.2 while 循環敘述
3.3 for 循環敘述
Chapter04 集合
4.1 集合簡介
4.2 陣列
4.3 列表(List)
4.4 集合(Set)
4.5 對應(Map)
4.6 佇列(Queue)
4.7 堆疊(Stack)
Chapter05 函數
5.1 函數
5.2 值函數
5.3 高階函數
5.4 閉包
5.5 函數柯里化(Currying)
5.6 部分應用函數
5.7 偏函數
Chapter06 Scala 物件導向程式設計(上)
6.1 類別與物件
6.2 主建構函數
6.3 輔助建構函數
6.4 繼承與多形
6.5 成員存取控制
6.6 抽象類別
6.7 內部類別與內建物件
6.8 匿名類別
Chapter07 Scala 物件導向程式設計(下)
7.1 trait 簡介
7.2 trait 的使用
7.3 trait 與類別
7.4 多重繼承問題
7.5 本身類型
Chapter08 套件(package)
8.1 套件的定義
8.2 套件的使用和作用域
8.3 套件物件
8.4 import 進階特性
Chapter09 模式比對
9.1 模式比對簡介
9.2 模式符合的7 大類型
9.3 模式比對原理
9.4 正規表示法與模式比對
9.5 for 循環中的模式比對
9.6 模式比對與範例類別、範例物件
Chapter10 自動轉型
10.1 自動轉型簡介
10.2 自動轉型函數
10.3 隱式類別與隱式物件
10.4 隱式參數與隱式值
10.5 自動轉型規則與問題
Chapter11 型態參數
11.1 類別與類型
11.2 泛型
11.3 類型變數界定
11.4 視圖界定
11.5 上下文界定
11.6 多重界定
11.7 協變與逆變
11.8 進階類型
Chapter12 Scala 平行處理程式設計基礎
12.1 Scala 平行處理程式設計簡介
12.2 Actor
12.3 Typed Actor
12.4 Dispatcher
12.5 Router
12.6 容錯
Chapter13 Scala 與Java 的互動操作
13.1 Java 與Scala 集合互動操作
13.2 Scala 與Java 泛型互動操作
13.3 Scala trait 在Java 中的使用
13.4 Scala 與Java 異常處理互動操作
ISBN: 9789863794844