介绍DefaultConfig类的组成。
 
 
1. DefaultConfig
 
DefaultConfig是Config的子类。其定义位于system/Config.scala:
 
他直接使用Config的第一个(primary)构造方法。在Intellij IDEA中,按住CTRL点击extends后的Config,可以直接定位到使用的构造方法:
 
PS. 作为对比,找一个使用第二个(secondary)构造方法的子类:
 
在Intellij IDEA中,按住CTRL点击extends后的Config,可以直接定位到使用的构造方法:
注意光标位置的不同。
 
DefaultConfig 由WithNBigCores和BaseConfig连接组成。++使用的是Parameters类中定义的方法,他把两个Parameters对象组合成为一个ChainParameters对象:
 
 
2. WithNBigCores
 
表示大核的个数及每个核的配置。
 
1) 配置项存储在PartialParameters中,需要动态匹配才能获取到;
2) 只包含一个配置项,其key为RocketTilesKey,继承在Field:
3) 配置项的值是一个RocketTileParams链表。我们把最后一行稍微改一下:
把光标定位到_ret上,使用Alt+Enter快捷键看Intellij IDEA有没有操作提示:
Enter键选择“Add type annotation to value definition”:
可以看到返回值类型为Seq[RocketTileParams]。这是一个小技巧。
 
4) 其中使用site(SystemBusKey)获取系统总线的配置值。
 
 
3. BaseConfig
 
其定义形式与DefaultConfig一致,多个Config组合成为一个BaseConfig。
 
 
4. 构造过程
 
整理一下DefaultConfig实例化的过程。
 
new DefaultConfig
1) 首先会调用其父类的构造方法;若要调用其父类的构造方法,则需要为之准备参数:
也就是创建Parameters p, p = new WithNBigCores(1) ++ new BaseConfig
 
2) 分别实例化WithNBigCores和BaseConfig;
 
3) 把WithNBigCores和BaseConfig的实例使用方法++组合到一起;
 
4) 调用Config的构造方法,产生DefaultConfig的实例;
 
最终构造的结果如下图:
其中,BaseConfig中只保留了最前面的两项配置。
 
 
5. 查找过程
 
假设有一个DefaultConfig的实例dftCfgInst,dftCfgInst(RocketTilesKey)的查找过程如下:
 
1) dftCfgInst(RocketTilesKey)调用的是View中的方法:
 
2) View.apply(pname)调用View.apply(pname, this);
 
3) View.apply(pname, this)调用find(pname, site);注意这里的site为this,也就是dftCfgInst对象本身;
 
4) find(pname, site)在Parameters中实现为:
所以调用chain(site, new TerminalView, pname),其中site为dftCfgInst;
 
5) chain(site, new TerminalView, pname)在Config中实现为:
委托给p的chain方法。
 
6) 这里dftCfgInst的p为ChainParameters,其chain方法定义为:
委托给x的chain方法;
 
7) 这里的x为WithNBigCores,是一个Config对象。如前所述,其chain委托给p.chain。这里的p为PartialParameters;
 
8) PartialParameters的实现如下:
在这里可以找到RocketTilesKey,也就是g.isDefaultAt(pname)返回真。
 
整理成表格如下:
 
 

Rocket - config - DefaultConfig的更多相关文章

  1. Rocket - config - implicit Parameters

    https://mp.weixin.qq.com/s/OH_Z1gdSUpfgM-tjx0OlrA   追溯配置信息的源头.   0. HasRocketCoreParameters   ​​ Has ...

  2. Rocket - config - Configs

    https://mp.weixin.qq.com/s/z2gUYuYQAHQCa_5HZcBszw   介绍各个配置项的组织方式.   参考链接: https://docs.qq.com/sheet/ ...

  3. Rocket - config - Parameters

    https://mp.weixin.qq.com/s/uLEr9gAFaMDIXa8S9xJVTw   介绍配置类Parameters及其伴生对象的实现.   参考链接: https://docs.q ...

  4. Rocket - config - Keys & Params

    https://mp.weixin.qq.com/s/Y42EWrO7IoHRD_yHD4iRLA   介绍配置项.配置值以及他们的使用方式.   参考链接: https://docs.qq.com/ ...

  5. Rocket - config - View

    https://mp.weixin.qq.com/s/b5o3s2DgqOz3-iK8FqPeLQ   介绍配置相关的基础类及其继承关系.   参考链接: https://github.com/fre ...

  6. .数据库连接池技术:DBCP和C3P0

    数据库连接池技术:DBCP和C3P0 1.什么是数据库连接池 已知的方法是需要访问数据库的时候进行一次数据库的连接,对数据库操作完之后再释放这个连接,通常这样业务是缺点很明显的: 用户每次请求都需要向 ...

  7. 快速的搭建JFinal的ORM框架示例

    JFinal默认用的是Freemarker作为视图. 所以,打架还是准备好俩个jar包吧! freemarker-2.3.16.jar JFinal-bin-1.5.jar 新建web工程和添加lib ...

  8. 使用c3p0连接池

    首先我们需要知道为什么要使用连接池:因为jdbc没有保持连接的能力,一旦超过一定时间没有使用(大约几百毫秒),连接就会被自动释放掉,每次新建连接都需要140毫秒左右的时间而C3P0连接池会池化连接,随 ...

  9. Jfinal 入门

    Jfinal 入门 IDE----->IDEA 新建项目 新建web项目 添加maven特性 方便导入jar包,不用一个个导入了 配置pom.xml <dependencies> & ...

随机推荐

  1. Course Selection System ZOJ - 3956 01背包+思维

    Course Selection System ZOJ - 3956 这个题目居然是一个01背包,我觉得好难想啊,根本就没有想到. 这个题目把题目给的转化为  ans = a*a-a*b-b*b 这个 ...

  2. ACM入门问题:最大利益问题

    设最大的利益为maxv,最小值为minv 1.求最大利益的简单算法 ;j<=n-;j++) ;i<=j-;i++) maxv =(maxv与R[j]-R[i]中较大的一个) maxv=ma ...

  3. 送你一份Redis书单,以后使用缓存的问题不用再问我啦!

    点击蓝色"程序员书单"关注我哟 加个"星标",每天带你读好书!

  4. (一)Redis介绍

    1 背景 在早期的互联网Web 1.0时代,大部分企业还是采用传统的企业级单体应用架构,而一时间蜂拥而至的巨大用户流量使得这种架构难以支撑,通过对诸多系统架构实施以及对巨大用户流量的分析过程中发现,其 ...

  5. Spring Cloud学习 之 Spring Cloud Hystrix(断路器原理)

    断路器定义: public interface HystrixCircuitBreaker { // 每个Hystrix都通过它判断是否被执行 public boolean allowRequest( ...

  6. 【Hadoop离线基础总结】MapReduce入门

    MapReduce入门 Mapreduce思想 概述 MapReduce的思想核心是分而治之,适用于大量复杂的任务处理场景(大规模数据处理场景). 最主要的特点就是把一个大的问题,划分成很多小的子问题 ...

  7. 图数据库 Nebula Graph 是什么

    图数据库(英语:Graph Database)是一个使用图结构进行语义查询的数据库.该系统的关键概念是图,形式上是点 (Node 或者 Vertex) 和边 (Edge 或者 Relationship ...

  8. ASP.NET Core on K8S学习之旅(13)Ocelot API网关接入

    本篇已加入<.NET Core on K8S学习实践系列文章索引>,可以点击查看更多容器化技术相关系列文章. 上一篇介绍了Ingress的基本概念和Nginx Ingress的基本配置和使 ...

  9. Java中this()和super()

    Java关键字this只能用于方法体中.this只能在类中的非静态方法中使用,静态方法和静态的代码块中绝对不能出现this,并且this只和特定的对象关联,而不和类关联,同一个类的不同对象有不同的th ...

  10. POI 导入excel数据自动封装成model对象--代码

    所有的代码如下: import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; ...