scala快速入门系列【scala简介】

2021-01-26 11:12:49 浏览数 (1)

在scala专栏已经写过两篇博文,为大家详细地介绍了如何在windows上安装scala并与IDEA进行集成。

相信大家可能已经把环境都配置好了,但可能对scala的概念还是一个未知数。所以小菌打算出一个scala快速入门系列,供大家学习使用。作为快速入门系列第一篇博客,本篇博客先为大家带来scala基本介绍

简介

scala是运行在JVM上的多范式编程语言,同时支持面向对象面向函数编程。

早期,scala刚出现的时候,并没有怎么引起重视,随着SparkKafka这样基于scala的大数据框架的兴起,scala逐步进入大数据开发者的眼帘。scala的主要优势是它的表达性。

接下来,我们要来学习:

  • 为什么要使用scala?
  • 通过两个案例对比Java语言和scala语言
为什么使用scala
  • 开发大数据应用程序(Spark程序、Flink程序)
  • 表达能力强,一行代码抵得上Java多行,开发速度快。
  • 兼容Java,可以访问庞大的Java类库,例如:操作mysql,redis,freemarker,activemq等等。

scala对比Java

下面通过两个案例,体会分别使用java和scala实现的代码数量。

案例一

定义三个实体类(用户类,订单,商品)

Java代码

代码语言:javascript复制
/*** 用户实体类 */ 
 public class User {

 private String name; 
 
 private List<Order> orders; 
 
 public String getName() { 
 return name;
 }
 
 public void setName(String name) { 
 this.name = name; 
 }

 public List<Order> getOrders() { 
 return orders; 
 }
 
 public void setOrders(List<Order> orders) { 
 this.orders = orders; 
 }

 }
代码语言:javascript复制
/*** 订单实体类 */ 
 public class Order {
 
 private int id; 
 
 private List<Product> products; 
 
 public int getId() {
  return id; 
 }
 
 public void setId(int id) { 
 this.id = id; 
 }
 
 public List<Product> getProducts() {
  return products; 
 }
 
 public void setProducts(List<Product> products) { 
this.products = products; 
} 

}
代码语言:javascript复制
/*** 商品实体类 */ 
public class Product { 

private int id; 
private String category;


 public int getId() {
  return id; 
  }

public void setId(int id) {
 this.id = id; 
 }

public String getCategory() { 
 return category;

 }

public void setCategory(String category) { 
this.category = category;

} 
}

scala代码

代码语言:javascript复制
case class User(var name:String, var orders:List[Order]) // 用户实体类 
case class Order(var id:Int, var products:List[Product]) // 订单实体类 
case class Product(var id:Int, var category:String) // 商品实体类
案例二

有一个字符串(数字)列表,我们想将该列表中所有的字符串转换为整数。

Java代码

代码语言:javascript复制
// 创建一个Integer类型的列表
 List<Integer> ints = new ArrayList<Integer>(); 
 for (String s : list) { 
 ints.add(Integer.parseInt(s)); 
 }

scala代码

代码语言:javascript复制
val ints = list.map(s => s.toInt)

还记得在简介中谈到的,scala的主要优势是它的表达性。没错,相比于java而言,scala可以用更少的代码"优雅"地表达出我们所想。所以,scala足以成为我们程序员必须涉猎的语言之一。

作为scala快速入门系列的第一篇博文,我也不想整太多的花里胡哨~有更多的疑惑可以自行解决,也可以私信问我。作为scala快速入门系列,力求快狠准,攻克大家的疑点,难点。

本篇到这里就结束了,希望大家可以多多支持。受益的或对大数据技术感兴趣的都可以点赞关注一下再走~~不定期更新,还有一系列的实用干货福利,敬请期待!!!

0 人点赞