- 浏览: 13229 次
- 性别:
- 来自: 南京
文章分类
最新评论
package com.linewell.modeldesgin.responsechain
/**
* 职责链模式,自我感觉和akka的管理机制很像
* Created by ctao on 2015/8/30.
*/
/**
* 审批对象
* @param amount 金额
* @param number 编号
* @param purpose 采购目的
*/
case class PurchaseRequest(amount: Double, number: Int, purpose: String)
/**
* 抽象处理者,审批者类
* @param name 审批人姓名
*/
abstract class Approve(name: String) {
/**
* 定义后继对象
*/
protected var successor: Approve = _
/**
* 设置后继对象
* @param approve 审批者类
*/
def setSuccessor(approve: Approve) = successor = approve
/**
* 抽象处理审批请求方法
* @param request 审批对象
*/
def processRequest(request: PurchaseRequest): Unit
}
/**
* 主任类
* @param name 审批人姓名
*/
class Director(name: String) extends Approve(name) {
override def processRequest(request: PurchaseRequest) = request.amount match {
case x: Double if x < 50000 =>
println(s"主任$name 审批采购单:" + request.number + ",金额:" + request.amount + "元,采购目的:" + request.purpose)
case _ => this.successor.processRequest(request)
}
}
/**
* 副董事长类
* @param name 审批人姓名
*/
class VicePresident(name: String) extends Approve(name) {
override def processRequest(request: PurchaseRequest) = request.amount match {
case x: Double if x < 100000 =>
println(s"副董事长$name 审批采购单:" + request.number + ",金额:" + request.amount + "元,采购目的:" + request.purpose)
case _ => this.successor.processRequest(request)
}
}
/**
* 董事长类
* @param name 审批人姓名
*/
class President(name: String) extends Approve(name) {
override def processRequest(request: PurchaseRequest) = request.amount match {
case x: Double if x < 500000 =>
println(s"董事长$name 审批采购单:" + request.number + ",金额:" + request.amount + "元,采购目的:" + request.purpose)
case _ => this.successor.processRequest(request)
}
}
/**
* 董事会类
* @param name 审批人姓名
*/
class Congress(name: String) extends Approve(name) {
override def processRequest(request: PurchaseRequest) =
println("召开董事会审批采购单:" + request.number + ",金额:" + request.amount + "元,采购目的:" + request.purpose)
}
package com.linewell.modeldesgin.responsechain
/**
* 测试客户端
* Created by ctao on 2015/8/30.
*/
object Client extends App {
val ZH: Approve = new Director("周华")
val YJY: Approve = new VicePresident("游建友")
val WZX: Approve = new President("吴志雄")
val meeting: Approve = new Congress("董事会")
ZH.setSuccessor(YJY)
YJY.setSuccessor(WZX)
WZX.setSuccessor(meeting)
ZH.processRequest(PurchaseRequest(45000, 1001, "大数据卡口项目"))
ZH.processRequest(PurchaseRequest(60000, 1002, "服务器购置"))
ZH.processRequest(PurchaseRequest(145000, 1003, "星环开科技专利购买"))
ZH.processRequest(PurchaseRequest(1145000, 1004, "公司并购"))
}
/**
* 职责链模式,自我感觉和akka的管理机制很像
* Created by ctao on 2015/8/30.
*/
/**
* 审批对象
* @param amount 金额
* @param number 编号
* @param purpose 采购目的
*/
case class PurchaseRequest(amount: Double, number: Int, purpose: String)
/**
* 抽象处理者,审批者类
* @param name 审批人姓名
*/
abstract class Approve(name: String) {
/**
* 定义后继对象
*/
protected var successor: Approve = _
/**
* 设置后继对象
* @param approve 审批者类
*/
def setSuccessor(approve: Approve) = successor = approve
/**
* 抽象处理审批请求方法
* @param request 审批对象
*/
def processRequest(request: PurchaseRequest): Unit
}
/**
* 主任类
* @param name 审批人姓名
*/
class Director(name: String) extends Approve(name) {
override def processRequest(request: PurchaseRequest) = request.amount match {
case x: Double if x < 50000 =>
println(s"主任$name 审批采购单:" + request.number + ",金额:" + request.amount + "元,采购目的:" + request.purpose)
case _ => this.successor.processRequest(request)
}
}
/**
* 副董事长类
* @param name 审批人姓名
*/
class VicePresident(name: String) extends Approve(name) {
override def processRequest(request: PurchaseRequest) = request.amount match {
case x: Double if x < 100000 =>
println(s"副董事长$name 审批采购单:" + request.number + ",金额:" + request.amount + "元,采购目的:" + request.purpose)
case _ => this.successor.processRequest(request)
}
}
/**
* 董事长类
* @param name 审批人姓名
*/
class President(name: String) extends Approve(name) {
override def processRequest(request: PurchaseRequest) = request.amount match {
case x: Double if x < 500000 =>
println(s"董事长$name 审批采购单:" + request.number + ",金额:" + request.amount + "元,采购目的:" + request.purpose)
case _ => this.successor.processRequest(request)
}
}
/**
* 董事会类
* @param name 审批人姓名
*/
class Congress(name: String) extends Approve(name) {
override def processRequest(request: PurchaseRequest) =
println("召开董事会审批采购单:" + request.number + ",金额:" + request.amount + "元,采购目的:" + request.purpose)
}
package com.linewell.modeldesgin.responsechain
/**
* 测试客户端
* Created by ctao on 2015/8/30.
*/
object Client extends App {
val ZH: Approve = new Director("周华")
val YJY: Approve = new VicePresident("游建友")
val WZX: Approve = new President("吴志雄")
val meeting: Approve = new Congress("董事会")
ZH.setSuccessor(YJY)
YJY.setSuccessor(WZX)
WZX.setSuccessor(meeting)
ZH.processRequest(PurchaseRequest(45000, 1001, "大数据卡口项目"))
ZH.processRequest(PurchaseRequest(60000, 1002, "服务器购置"))
ZH.processRequest(PurchaseRequest(145000, 1003, "星环开科技专利购买"))
ZH.processRequest(PurchaseRequest(1145000, 1004, "公司并购"))
}
发表评论
-
linux mongodb3安装
2015-10-29 15:33 261http://blog.csdn.net/cjuexuan/a ... -
scala代码重构(用递归代替var和while)
2015-09-07 19:47 382原有代码,其中使用了while循环和var /** ... -
再探设计模式之观察者模式(股票通知系统)
2015-09-05 10:28 498package com.linewell.modeldesig ... -
再探设计模式之状态模式(纸牌游戏的开发)
2015-09-04 13:52 538状态模式主要用于检测和切换状态,在状态模式下状态的转化对于客户 ... -
再探设计模式之访问者模式
2015-09-03 14:44 481访问者模式的使用条件比较苛刻主要可以以用于新增访问者时只需要 ... -
scala实现访问者模式
2015-09-02 20:54 376package com.linewell.modeldesgi ... -
scala实现模版方法模式
2015-09-02 20:54 416package com.linewell.modeldesgi ... -
scala实现状态模式
2015-09-02 16:37 387package com.linewell.modeldesgi ... -
scala实现观察者模式
2015-09-02 16:35 589package com.linewell.modeldesgi ... -
scala实现迭代器模式
2015-09-01 22:56 466package com.linewell.modeldesgi ... -
scala实现备忘录模式
2015-09-01 22:54 341package com.linewell.modeldesgi ... -
scala实现中介者模式
2015-09-01 14:48 287package com.linewell.modeldesgi ... -
scala实现解释器模式
2015-08-31 20:20 317本来是看解释器模式,但感觉scala的实现的流利接口可以更优雅 ... -
scala实现命令模式
2015-08-30 21:20 271package com.linewell.modeldesgi ... -
scala实现享元模式
2015-08-30 00:17 336package com.linewell.modeldesgi ... -
scala实现代理模式
2015-08-30 00:16 488package com.linewell.modeldesgi ... -
scala实现外观模式
2015-08-28 21:41 311package com.linewell.modeldesgi ... -
scala实现装饰者模式
2015-08-16 19:52 396package com.linewell.modeldesgi ... -
scala实现组合模式
2015-08-16 11:14 834package com.linewell.modeldesgi ... -
scala实现桥接模式
2015-08-16 11:13 312package com.linewell.modeldesgi ...
相关推荐
scala:Scala和设计模式 ...在当前软件Software设计中最流行要算GoF这本书...用方便性也很重要不妨让我们来看看Scala(种类似Ruby/Lisp的类语言它定程度上降低了模式实现繁琐)中常用 些模式 ; ; ; ; 1.Singleton(单体模式) ;
scala连接redis哨兵模式 demo 使用scala的redis库(csdn)————程序
响应式架构 消息模式Actor实现与Scala.Akka应用集成 响应式架构 消息模式Actor实现与Scala.Akka应用集成
自己用scala实现的朴素贝叶斯算法。最近学习machine learning,由于之前学习了spark,于是使用scala尝试写写代码
差分进化算法的Scala实现_Scala_代码_下载
scala 设计模式,详细讲述scala设计模式
scala正则表达式在模式匹配中的应用:提取模式的分组值,通过代码理解正则表达式与模式匹配的原理。
消息模式Actor实现与Scala、Akka应用集成
Scala设计模式,Scala高阶参考书。
scala for循环中的模式匹配:1)变量模式匹配2)常量模式匹配3)变量绑定模式匹配4)类型模式匹配5)构造函数模式匹配6)序列模式匹配
不到一百行的代码教你在spark平台中使用scala实现kmeans算法。简单易懂,大量注释。适合初学者参考理解。本程序在intelliJ IDEA2016.1.1 中编程,运行在spark1.6.1 scala2.10.4本地模式下运行成功。 数据集:(其实...
[Manning Publications] Play 框架开发 (Scala 实现) (英文版) [出版日期] 2013年10月11日[图书页数] 328页 [图书语言] 英语[图书格式] PDF 格式
scala语言和python一样都是交互式的语言,操作简单。这是wordcount的scala实现,简单明了,比java实现简单很多,希望对大家有所帮助
响应式架构++消息模式Actor实现与Scala.Akka应用集成+,沃恩·弗农+
[Packt Publishing] SBT 入门教程 (Scala 实现) (英文版) [Packt Publishing] Getting Started with SBT for Scala (E-Book) ☆ 图书概要:☆ Equip yourself with a high-productivity work environment using ...
响应式架构 消息模式Actor实现与Scala.Akka应用集成 高清扫描版
基于spark-ml,scala实现gbdt 算法,附带libsvm训练集和普通训练集实现,GBDT (Gradient Boosting Decision Tree) 梯度提升迭代决策树。GBDT 也是 Boosting 算法的一种,但是和 AdaBoost 算法不同(AdaBoost 算法...
Scala语法简明教程.pdf