Scala快速入门简介——(一)

2021-04-13 10:58:08 浏览数 (1)

scala简介

代码语言:javascript复制
scala是运行在`JVM`上的多范式编程语言,同时支持面向对象和面向函数编程

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

接下来,我们要来学习:

代码语言:javascript复制
- 1.为什么要使用scala?
- 2.通过两个案例对比Java语言和scala语言

1.为什么使用scala?

代码语言:javascript复制
- 开发大数据应用程序(Spark程序、Flink程序)

- 表达能力强,一行代码抵得上Java多行,开发速度快
- 兼容Java,可以访问庞大的Java类库,例如:操作mysql、
- redis、freemarker、activemq等等

2.scala对比Java

代码语言:javascript复制
下面通过两个案例,分别使用java和scala实现的代码数量
案例
代码语言:javascript复制
定义三个实体类(用户、订单、商品)
Java代码
代码语言:javascript复制
/**
 * 用户实体类
 */
public class User {
    private String name;
    private List orders;

    public String getName() {
    	return name;
    }

    public void setName(String name) {
    	this.name = name;
    }

    public List getOrders() {
    	return orders;
    }

    public void setOrders(List orders) {
    	this.orders = orders;
    }
}




/**
 * 订单实体类
 */
public class Order {
    private int id;
    private List products;

    public int getId() {
    	return id;
    }

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

    public List getProducts() {
    	return products;
    }

    public void setProducts(List products) {
    	this.products = products;
    }
}



/**
 * 商品实体类
 */
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)  // 商品实体类

0 人点赞