- 浏览: 85427 次
- 性别:
- 来自: 成都
-
最新评论
-
荆人七十:
谢谢分享~
在eclipse上面搭建Clojure开发运行环境 -
lanily:
楼主,跟你学clojure了,我想请教一个问题:本人事先是用j ...
Clojure细节之form和special form的区别 -
Dead_knight:
http://code.google.com/p/clojur ...
practical_clojure chapter3 控制程序流(未完) -
石建武:
谢谢。提供的离线包。但如果通过‘install new’方式, ...
在eclipse上面搭建Clojure开发运行环境 -
songry:
linkerlin 写道标题里面的 未完 ,啥时候能去掉?可以 ...
practical_clojure chapter3 控制程序流(未完)
注:本文基于jdk1.6和Clojure1.2
工厂方法
工厂方法模式定义了一个创建对象的接口,由子类来决定实例化哪一个类,意即将实例化推迟到子类。
当然,这个说法本身是干巴巴概念性的。让我们针对上篇简单工厂 的例子考虑一下,我们在SimpleFactory中
已经定义了产生IProduct实例的方法,这是在调用之前就定好了 产生IProduct实例的规则,可是如果遇到
需要在调用时才决定这个规则的情况时,SimpleFactory就无法满足了。
比如说,某次调用中需要在参数productType等于1时返回Product1, 参数productType等于2时返回
Product2, SimpleFactory正好能满足这种情况,没问题;但另外一次调用时需要在 参数productType等于
1时返回Product2, 参数productType等于2时返回null, 参数productType等于3时返回Product1,
SimpleFactory就傻眼了......
当然,我们一拍脑袋就想出办法了--在SimpleFactory的 factory方法中 再加一个参数来增加规则:
/** * 根据产品类型和规则来生产产品 * @param productType * @return */ public static IProduct factory(String productType,String regulation){ if(regulation.equals("1")){ if(productType.equals("1")) return new Product1(); else if(productType.equals("2")) return new Product2(); }else if(regulation.equals("2")){ if(productType.equals("1")) return new Product2(); else if(productType.equals("3")) return new Product1(); } return null; }
哈哈,这不就解决问题了吗?这样做确实解决了眼前的问题而且能够正常工作,但是,如果产品的规则再增添
一种,比如regulation3,毫无疑问,我们又需要再去修改SimpleFactory的factory方法;规则再增加一种,好的,
继续修改SimpleFactory的factory方法...以此类推, SimpleFactory的factory方法会变得越来越大,变成冗长
的、逻辑关系复杂的代码泥团,谁要再去修改这个方法,必须仔细研读代码,小心翼翼地添加类型和规则,生怕
影响到了所有调用它的地方。改完之后,大骂一通设计人员,然后到javaeye上面发一篇《碰到史上最烂JAVA项目》
这样的帖子,然后大家告诉你:“国内项目很多都这样,没办法,找到工资待遇高的就走吧”。
问题在于,这种解决方法是面向过程而非面向对象的。记得面向对象的设计原则吗,面向接口而非面向实现类
编程,对修改封闭对扩展开放。所以,工厂方法模式就出场了:
/** * 工厂方法接口 * @author RoySong */ public interface IFactoryMethod { /** * 根据产品类型生产产品 * @param productType * @return */ public IProduct factory(String productType); } /** * 规则1工厂 * @author RoySong */ public class Regulation1Factory implements IFactoryMethod { @Override public IProduct factory(String productType) { if(productType.equals("1")) return new Product1(); else if(productType.equals("2")) return new Product2(); return null; } } /** * 规则2工厂 * @author RoySong */ public class Regulation2Factory implements IFactoryMethod { @Override public IProduct factory(String productType) { if(productType.equals("1")) return new Product2(); else if(productType.equals("3")) return new Product1(); return null; } } /** * 工厂方法调用 * @author RoySong */ public class FactoryMethodTest { private IFactoryMethod iFactoryMethod; public static void main(String[] args){ FactoryMethodTest fmt = new FactoryMethodTest(); //采用规则1工厂方法 fmt.setiFactoryMethod(new Regulation1Factory()); IProduct product1 = fmt.getiFactoryMethod().factory("1"); product1.use("regulation 1"); IProduct product2 = fmt.getiFactoryMethod().factory("2"); product2.use("regulation 1"); //采用规则2工厂方法 fmt.setiFactoryMethod(new Regulation2Factory()); product1 = fmt.getiFactoryMethod().factory("3"); product1.use("regulation 2"); product2 = fmt.getiFactoryMethod().factory("1"); product2.use("regulation 2"); } public void setiFactoryMethod(IFactoryMethod iFactoryMethod) { this.iFactoryMethod = iFactoryMethod; } public IFactoryMethod getiFactoryMethod() { return iFactoryMethod; } }
调用的结果是:
Product1 use:regulation 1 Product2 use:regulation 1 Product1 use:regulation 2 Product2 use:regulation 2
而在Clojure当中,工厂方法简直是信手拈来。首先我们定义两个产品:
(defn product1 [msg] (println "Product1 use:" msg)) (defn product2 [msg] (println "Product2 use:" msg))
然后我们定义两个规则工厂:
(defn regar1-factory [type] (cond (= 1 type) #'product1 (= 2 type) #'product2 true nil)) (defn regar2-factory [type] (cond (= 3 type) #'product1 (= 1 type) #'product2 true nil))
最后定义一个调用函数:
(defn use-product [fn type msg] ((fn type) msg))
我们注意到代码中有一个奇特的符号” #‘ “,这是个什么玩意儿呢?
实际上,这是Clojure中的一种取值方式,用于取得符号(比如product1)所映射的对象值(意即product1所
代表的整个函数体),而并非符号储存的对象的引用值(指针)。换句话说,我们的规则函数(regar*-factory)
所返回的是整个函数,而调用函数接受的参数fn也是一个函数。这就是函数式编程语言的最大特征之一,函数即
数据。你可以把函数作为返回值或者是参数。这也是函数式编程语言比指令式编程语言更加灵活(也更加难懂)的
原因之一。
回到例子,我们开始使用调用函数:
(use-product #'regar1-factory 1 "anything")
毫无意外的结果:
Product1 use: anything nil
再来一个:
(use-product #'regar2-factory 1 "something")
仍然是预期的结果:
Product2 use: something nil
这样,我们在Clojure里面就达到了运行时根据规则产生不同的对象的目的了。严格来说,上面的例子并非在
运行时才进行的实例化,应该通过宏(macro)来产生product1和product2,不过,为了代码的清晰和简单,
这儿暂时就这么写了。
附注:很久没有写工厂了,概念模糊了,这里面的java代码实际上不是工厂方法,而是抽象工厂。经朋友提醒才
想起来,原文先保留不动吧。
发表评论
-
Clojure细节之Reader
2012-05-10 15:19 0前言 Clojure中提供了多种reader语法糖来 ... -
Clojure细节之form和special form的区别
2012-05-07 14:26 2293前言 在lisp程序员看来,form和special ... -
Clojure入门-前言
2012-04-10 09:04 0前言 0.1 关于Clojure 在正式接触Clo ... -
使用c通过jni调用java
2012-04-02 12:01 9425编译环境: fedora16 gcc (GCC) ... -
clojure调用java方法时参数问题
2012-02-24 10:05 1991众所周知,clojure基于jvm,可以在不做引入的情 ... -
换零钱的clojure实现
2012-01-06 19:27 1870题目:有半美元、四分 ... -
clojure API学习(4) 程序流控制
2011-12-20 16:38 0本文基于jdk1.6和clojure1.2 if ... -
clojure API学习(3) 字符和字符串操作
2011-12-16 00:08 4711注:本文基于jdk1.6,clojur ... -
clojure的冒泡排序实现
2011-12-08 17:11 2204冒泡排序的基本概念是:依次比较相邻的两个数,将小数放在 ... -
Clojure-JVM上的函数式编程语言(17)数据库 作者: R. Mark Volkmann
2011-11-26 09:20 1876原帖地址:http://java.ociweb.com/mar ... -
clojure API学习(2) 比较操作
2011-11-26 08:59 2730注:本文基于jdk1.6,clojur ... -
clojure API学习(1) 数学运算
2011-11-24 22:32 3109附注:本文基于jdk1.6,clo ... -
Clojure-JVM上的函数式编程语言(16)Web应用 作者: R. Mark Volkmann
2011-11-19 11:37 2038原帖地址:http://java.ociweb.com/mar ... -
Clojure-JVM上的函数式编程语言(15) 桌面应用 作者: R. Mark Volkmann
2011-11-19 11:04 1576原帖地址:http://java.ociweb.com/mar ... -
Clojure-JVM上的函数式编程语言(14) 编辑器和开发环境 作者: R. Mark Volkmann
2011-11-19 10:31 1731原帖地址:http://java.ociweb.com/mar ... -
Clojure-JVM上的函数式编程语言(13)自动化测试 作者: R. Mark Volkmann
2011-11-17 21:25 1444原帖地址:http://java.ociweb.com/ma ... -
如何将Clojure作为java工程中的脚本
2011-11-17 09:57 0注:本文基于jdk1.6和Clojure1.2 -
Clojure-JVM上的函数式编程语言(12)编译 作者: R. Mark Volkmann
2011-11-17 11:52 2704原帖地址:http://java.ociweb.com/ma ... -
Clojure与java设计模式(3) 策略模式
2011-11-16 15:45 1899注:本文基于jdk1.6和Clojure1.2 策略模 ... -
在eclipse上面搭建Clojure开发运行环境
2011-11-15 13:30 12547首先,需要下 ...
相关推荐
【Java设计模式:工厂模式之简单工厂】 简单工厂模式是一种常用的设计模式,它提供了一种创建对象的最佳方式,尤其在需要根据条件创建不同类的对象时。在Java中,简单工厂模式通过一个工厂类来集中创建对象,避免了...
4. **组件化设计**:`nomnom.bunnicula` 遵循Clojure的组件模型,允许开发者根据需求组合和配置不同的组件,如连接池、消费者工厂等,实现高度定制化的解决方案。 5. **错误处理和回调**:框架提供了错误处理机制,...
在Java 8之前,Scala、Groovy和Clojure等基于JVM的语言已经广泛支持Lambda表达式,使得开发者能够更简洁地处理高阶函数。Java 8的引入,标志着这个强大的工具也被正式纳入Java的世界。 Lambda表达式在JVM层面上并不...
【AI】从头到脚详解如何创建部署Azure Web App的OpenAI项目源码
人脸识别项目实战
人工智能-人脸识别代码,采用cnn的架构识别代码
汽车配件制造业企业信息化整体解决方案
短期风速预测模型,IDBO-BiTCN-BiGRU-Multihead-Attention IDBO是,网上复现 评价指标:R方、MAE、MAPE、RMSE 附带测试数据集运行(风速数据) 提示:在MATLAB2024a上测试正常 ,短期风速预测模型; IDBO-BiTCN-BiGRU-Multihead-Attention; 评价指标: R方、MAE、MAPE、RMSE; 复现; 测试数据集; MATLAB 2024a,短期风速预测模型:IDBO-BiTCN-BiGRU-Attention集成模型
手势识别项目实战
在智慧园区建设的浪潮中,一个集高效、安全、便捷于一体的综合解决方案正逐步成为现代园区管理的标配。这一方案旨在解决传统园区面临的智能化水平低、信息孤岛、管理手段落后等痛点,通过信息化平台与智能硬件的深度融合,为园区带来前所未有的变革。 首先,智慧园区综合解决方案以提升园区整体智能化水平为核心,打破了信息孤岛现象。通过构建统一的智能运营中心(IOC),采用1+N模式,即一个智能运营中心集成多个应用系统,实现了园区内各系统的互联互通与数据共享。IOC运营中心如同园区的“智慧大脑”,利用大数据可视化技术,将园区安防、机电设备运行、车辆通行、人员流动、能源能耗等关键信息实时呈现在拼接巨屏上,管理者可直观掌握园区运行状态,实现科学决策。这种“万物互联”的能力不仅消除了系统间的壁垒,还大幅提升了管理效率,让园区管理更加精细化、智能化。 更令人兴奋的是,该方案融入了诸多前沿科技,让智慧园区充满了未来感。例如,利用AI视频分析技术,智慧园区实现了对人脸、车辆、行为的智能识别与追踪,不仅极大提升了安防水平,还能为园区提供精准的人流分析、车辆管理等增值服务。同时,无人机巡查、巡逻机器人等智能设备的加入,让园区安全无死角,管理更轻松。特别是巡逻机器人,不仅能进行360度地面全天候巡检,还能自主绕障、充电,甚至具备火灾预警、空气质量检测等环境感知能力,成为了园区管理的得力助手。此外,通过构建高精度数字孪生系统,将园区现实场景与数字世界完美融合,管理者可借助VR/AR技术进行远程巡检、设备维护等操作,仿佛置身于一个虚拟与现实交织的智慧世界。 最值得关注的是,智慧园区综合解决方案还带来了显著的经济与社会效益。通过优化园区管理流程,实现降本增效。例如,智能库存管理、及时响应采购需求等举措,大幅减少了库存积压与浪费;而设备自动化与远程监控则降低了维修与人力成本。同时,借助大数据分析技术,园区可精准把握产业趋势,优化招商策略,提高入驻企业满意度与营收水平。此外,智慧园区的低碳节能设计,通过能源分析与精细化管理,实现了能耗的显著降低,为园区可持续发展奠定了坚实基础。总之,这一综合解决方案不仅让园区管理变得更加智慧、高效,更为入驻企业与员工带来了更加舒适、便捷的工作与生活环境,是未来园区建设的必然趋势。
相亲交友系统源码 V10.5支持婚恋相亲、媒婆返利、红娘系统、商城系统等等 这款交友系统功能太多了,适合婚恋相亲,还有媒婆婚庆等等支持 PC和 H5还有小程序,可封装红年、APP,里面带安装教程
本资源《单片机也能玩双核之你想不到的C技巧系列——嵌入式实战》涵盖 双核单片机开发、C语言高级技巧、嵌入式系统优化 等核心内容,结合 实战案例与视频教程,帮助开发者深入理解并掌握高效编程技巧。 适用人群: 适合 嵌入式开发工程师、单片机开发者、电子信息相关专业学生,以及希望提升 C语言编程能力 和 嵌入式项目经验 的技术人员。 能学到什么: 双核单片机开发思路,提高并行处理能力。 C语言高级技巧,提升代码优化与执行效率。 嵌入式系统调试方法,掌握实际项目中的调试策略。 实战案例解析,学习如何在实际工程中应用双核技术。 阅读建议: 建议 先学习基础知识,再结合 示例代码与视频教程 进行实操,重点关注 代码优化、调试技巧与双核应用模式,通过实战演练提高嵌入式开发能力。
人脸识别项目源码实战
人脸识别项目源码实战
c语言学习
红外光伏缺陷目标检测模型,YOLOv8模型 基于红外光伏缺陷目标检测数据集训练,做了必要的数据增强处理,以达到缺陷类别间的平衡 可检测大面积热斑,单一热斑,二极管短路和异常低温四类缺陷 测试集指标如图所示 ,核心关键词:红外光伏缺陷目标检测模型; YOLOv8模型; 数据增强处理; 缺陷类别平衡; 大面积热斑; 单一热斑; 二极管短路; 异常低温。,基于YOLOv8的红外光伏缺陷检测模型
基于PLC的自动浇花控制系统 西门子1200PLC博途仿真,提供HMI画面,接线图,IO分配表,演示视频,简单讲解视频 博图15.1及以上版本均可使用 ,核心关键词: PLC自动浇花控制系统; 西门子1200PLC博途仿真; HMI画面; 接线图; IO分配表; 演示视频; 简单讲解视频; 博图15.1及以上版本。,基于PLC的自动浇花系统:西门子1200PLC博途仿真实践教程
在智慧园区建设的浪潮中,一个集高效、安全、便捷于一体的综合解决方案正逐步成为现代园区管理的标配。这一方案旨在解决传统园区面临的智能化水平低、信息孤岛、管理手段落后等痛点,通过信息化平台与智能硬件的深度融合,为园区带来前所未有的变革。 首先,智慧园区综合解决方案以提升园区整体智能化水平为核心,打破了信息孤岛现象。通过构建统一的智能运营中心(IOC),采用1+N模式,即一个智能运营中心集成多个应用系统,实现了园区内各系统的互联互通与数据共享。IOC运营中心如同园区的“智慧大脑”,利用大数据可视化技术,将园区安防、机电设备运行、车辆通行、人员流动、能源能耗等关键信息实时呈现在拼接巨屏上,管理者可直观掌握园区运行状态,实现科学决策。这种“万物互联”的能力不仅消除了系统间的壁垒,还大幅提升了管理效率,让园区管理更加精细化、智能化。 更令人兴奋的是,该方案融入了诸多前沿科技,让智慧园区充满了未来感。例如,利用AI视频分析技术,智慧园区实现了对人脸、车辆、行为的智能识别与追踪,不仅极大提升了安防水平,还能为园区提供精准的人流分析、车辆管理等增值服务。同时,无人机巡查、巡逻机器人等智能设备的加入,让园区安全无死角,管理更轻松。特别是巡逻机器人,不仅能进行360度地面全天候巡检,还能自主绕障、充电,甚至具备火灾预警、空气质量检测等环境感知能力,成为了园区管理的得力助手。此外,通过构建高精度数字孪生系统,将园区现实场景与数字世界完美融合,管理者可借助VR/AR技术进行远程巡检、设备维护等操作,仿佛置身于一个虚拟与现实交织的智慧世界。 最值得关注的是,智慧园区综合解决方案还带来了显著的经济与社会效益。通过优化园区管理流程,实现降本增效。例如,智能库存管理、及时响应采购需求等举措,大幅减少了库存积压与浪费;而设备自动化与远程监控则降低了维修与人力成本。同时,借助大数据分析技术,园区可精准把握产业趋势,优化招商策略,提高入驻企业满意度与营收水平。此外,智慧园区的低碳节能设计,通过能源分析与精细化管理,实现了能耗的显著降低,为园区可持续发展奠定了坚实基础。总之,这一综合解决方案不仅让园区管理变得更加智慧、高效,更为入驻企业与员工带来了更加舒适、便捷的工作与生活环境,是未来园区建设的必然趋势。
大型集团用户画像系统化标准化数字化用户主数据管理项目规划方案
基于STM32的水质 浊度检测仪设计与实现(详细设计说明书+ 10008-基于STM32的水质 浊度检测仪设计与实现(详细设计说明书+原理图PCB工程+源码工程+实物照片) 本次设计是设计一款水质检测设备,实现温度检查、水质检测的功能,将检测到的数据显示到显示器中,并实时记录系统的参数 本次系统需要对温度检测,使用的传感器为DS18B20,通过单总线的方式来完成系统温度检测 使用水质检测模块检查水的质量 通过传感器检测到的数据计算后的值实时刷新到显示器中,主要的功能包括以下几点: ①可以对温度实时检测; ②可以对水质实际值实时检测; ③水质浑浊预警 主要特点: 1.以STM32单片机为核心,配合水质模块; 2.主要完成系统的 功能控制、状态显示、信息检测以及报警硬件组建所单片机和传感器等元器件的选择; 3.完成系统控制的软件设计编程; 4.实现对水质检测、温度检查、预警的功能 内容包含: 1、原理图工程 2、PCB工程 3、源码工程 4、实物照片 5、详细介绍说明书-22531字 6、实物照片 7、浊度传感器资料