博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Scala学习第十一天 Scala中的apply实战详解
阅读量:2200 次
发布时间:2019-05-03

本文共 1363 字,大约阅读时间需要 4 分钟。

信息来源于 DT大数据梦工厂微信公众账号:DT_Spark

DT大数据梦工厂群号:302306504王家林老师微信号:wangjialinandroid

一、object中的apply实战详解

1、object ApplyTest是class ApplyTest的伴生对象
2、在object ApplyTest中,复写apply方法,在apply中打印输出,再用class ApplyTest的无参主构造器new出ApplyTest的实例

class ApplyTest{
def apply() = println("I am into Spark so much!!!") def haveAtry{ println("Have a try on apply!!!") }}object ApplyTest{
def apply(){ println("I am into Scala so much!!!") new ApplyTest }}object ApplyOperation {
def main(args: Array[String]){ val array = Array(1,2,3,4,5) val a = ApplyTest() a.haveATry /*我们这里没有使用new,是调用了类的伴生对象的apply, 通过apply方法new出类的对象实例,类中因为声明了haveATry ,所以可以调用haveATry.*/

(2)其实,我们采用object对象的apply方式的好处是,例如我们构建一个数组,数组里面有很多元素或其它的集合,我们不需要new一个对象。直接以object传递参数就好,另一方面,我们构建时,需要对实例对象单例控制的话,在apply中实现是非常好的,例如去判断身份,是否有权限去构造。

二、class中的apply实战详解

(1)class中的apply并不常见

class ApplyTest{
def apply() = println("I am into Spark so much!!!") def haveAtry{ println("Have a try on apply!!!") }}object ApplyTest{
def apply(){ println("I am into Scala so much!!!") new ApplyTest }}/*我们new一个ApplyTest类的对象,调用它的haveATry方法,如果我们要调用类的apply方法,用类构建的实例对象加个()*/object ApplyOperation extends App{
// val a = ApplyTest()// a.haveATry val a = new ApplyTest a.haveATry println(a())}

Scala 深入浅出实战经典(1-64讲)完整视频、PPT、代码下载:

百度云盘:

腾讯微云:

360云盘: 访问密码 45e2

Scala视频及其更新和其他资料(Spark公开课、安卓基础、移动互联网)下载:
百度云盘:

转载地址:http://qerub.baihongyu.com/

你可能感兴趣的文章
分布式系统理论基础1: 一致性、2PC和3PC
查看>>
分布式系统理论基础2 :CAP
查看>>
分布式系统理论基础3: 时间、时钟和事件顺序
查看>>
分布式系统理论基础4:Paxos
查看>>
分布式系统理论基础5:选举、多数派和租约
查看>>
分布式系统理论基础6:Raft、Zab
查看>>
分布式系统理论进阶7:Paxos变种和优化
查看>>
分布式系统理论基础8:zookeeper分布式协调服务
查看>>
搞懂分布式技术1:分布式系统的一些基本概念
查看>>
搞懂分布式技术2:分布式一致性协议与Paxos,Raft算法
查看>>
搞懂分布式技术3:初探分布式协调服务zookeeper
查看>>
搞懂分布式技术4:ZAB协议概述与选主流程详解
查看>>
搞懂分布式技术5:Zookeeper的配置与集群管理实战
查看>>
搞懂分布式技术6:Zookeeper典型应用场景及实践
查看>>
搞懂分布式技术10:LVS实现负载均衡的原理与实践
查看>>
搞懂分布式技术11:分布式session解决方案与一致性hash
查看>>
搞懂分布式技术12:分布式ID生成方案
查看>>
搞懂分布式技术13:缓存的那些事
查看>>
搞懂分布式技术14:Spring Boot使用注解集成Redis缓存
查看>>
搞懂分布式技术15:缓存更新的套路
查看>>