



全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
序在java中,设计模式是多态和封装的重要表现形式,采用设计模式能够极大地提升可维护性和可扩展性,那么,同样工作在jvm上面的Clojure能否运用这些模式,或者说是否同样需要这些模式呢?注:本文基于jdk1.6和Clojure1.2简单工厂先看看简单工厂的java代码:首先定义产品的接口:1. publicinterfaceIProduct 2. 3. /* 4. *使用产品 5. *parammsg 6. */7. publicvoiduse(Stringmsg); 8. 然后是实现了这个接口的两个具体产品Product1和Product2:1. publicclassProduct1implementsIProduct 2. 3. Override4. publicvoiduse(Stringmsg) 5. System.out.println(Product1use:+msg); 6. 7. 8. 9. 10. publicclassProduct2implementsIProduct 11. 12. Override13. publicvoiduse(Stringmsg) 14. System.out.println(Product2use:+msg); 15. 16. 17. 最后是根据类型获取产品的简单工厂:1. publicclassSimpleFactory 2. 3. /* 4. *根据产品类型生产产品 5. *paramproductType 6. *return 7. */8. publicstaticIProductfactory(StringproductType) 9. if(productType.equals(1) 10. returnnewProduct1(); 11. elseif(productType.equals(2) 12. returnnewProduct2(); 13. returnnull; 14. 15. 这样,我们在java中就构建了能够生产出两个不同产品的简单工厂了。接下来,我们调用一下:1. /* 2. *简单工厂调用 3. *authorRoySong-2011-10-27 4. */5. publicclassSimpleFactoryTest 6. 7. /* 8. *paramargs 9. */10. publicstaticvoidmain(Stringargs) 11. IProductproduct1=SimpleFactory.factory(1); 12. product1.use(something); 13. 14. IProductproduct2=SimpleFactory.factory(2); 15. product2.use(something); 16. 17. 18. 运行这个调用程序,我们能够得到预期的结果:1. Product1use:something 2. Product2use:something那么,在Clojure中应该如何实现呢?首先,让我们再回顾一下采用简单工厂的目的,这是为了将业务对象的产生和业务方法的执行进行解耦,使得业务方法执行时无须关注业务对象的类型。为了 达到这个目的,我们提取了业务对象的接口IProduct(在实际的应用中也有可能是一个父类Product),它的里面包含了所有业务对象的共同操作 use(在实际应用中可能不止这一种业务操作,当然也不叫use)的方法声明。然后,由SimplyFactory来创建IProduct的实例对象,然 后调用use业务方法。在这个时候,调用方法是无须关注被调用的具体是哪个实例对象-Product1还是Product2。好吧,为了业务对象的产生和业务方法的执行解耦。然后,Clojure中没有对象一说,方法倒是有,不过叫做函数。于是,问题解决了,没有对象,则无须对对象的产生进行解耦。本文结束。抛开上面的文字游戏不谈,实际上Clojure的解决方式更为灵活,这是由其语言特性所决定的。在java中,一切都是对象(除了原始类型),而类 和接口是对象的定义,包含了有关对象动作方式的相关信息,比如名称、方法、属性和事件等。所以,在java应用中,能够使用的最小粒度的东西就是对象,如 果需要调用某个实例方法,首先需要实例化某个对象,然后调用这个对象的方法;如果需要调用某个静态方法,需要找到静态方法所属的类,然后以类名.方法名的 形式来调用。而在Clojure中,函数是第一类对象,它无须依附对象或者类而存在(实际上,在几乎所有的函数式编程语言中都是这样)。换句话说,我们调 用某个方法无须首先实例化某个对象或者找到某个类。那么,针对上面的例子,我们可以说,实际上我们需要的是根据不同的类型获取两个不同的业务处理方法而已。1. (defnsimply-factorytype 2. (cond 3. (=1type)(fnmsg(printlnProduct1use:msg) 4. (=2type)(fnmsg(printlnProduct2use:msg)在上面的代码中,我们定义了一个函数simply-factory,它接受一个参数type,然后根据type的值为1或者2返回对应的函数。实际上,我们从内容上可以看出来,这两个函数就分别对应了之前我们定义的Product1和Product2中的use方法。接下来,我们就看看调用和产生的输出:1. user(simply-factory1)something) 2. Product1use:something 3. nil 4. user(simply-factory2)something) 5. Product2use:something 6. nil已经达到了我们之前想要的结果,对不对?让我们再看看调用方法的代码(simply-factory 1) something),(simply-factory 1)代表传入参数1调用simply-factory函数,返回的是一个匿名函数;而(simply-factory 1) something)整体就代表将something传入simply-factory函数返回的匿名函数,然后我们就得到了预期的结 果:Product1 use: something。我相信你已经看出来了,Clojure中函数的调用方式是:(函数名 参数)这个样子的。不过这个样子跟上面的java代码似乎差别有点大,让我们对这个调用方式做一点小小的修改:1. user(defproduct1(simply-factory1) 2. #user/product1 3. user(product1something) 4. Product1use:something 5. nil 6. user(defproduct2(simply-factory2) 7. #user/product2 8. user(product2something) 9. Product2use:something 10. nil这样子应该就能够和之前的java代码一一对应了,其中1. IProductproduct1=SimpleFactory.factory(1);对应1. (def
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年国际贸易专员职业素质评估考试试题及答案解析
- 2025年村级物流安全员笔试冲刺题
- 课件专业评审表评价
- 课件与乐器的融合
- 2025年建筑设计师专业面试模拟题与案例分析
- 2025年竞聘笔试县公司电力电商解析题
- 2025年香材鉴别师初级笔试模拟试卷
- 2025年供销社考试模拟试卷及答案
- 应用写作孙秀秋教学课件
- 2025年安全生产法规考试十套题及答案
- 《刺络放血疗法》课件
- 沪教深圳版八年级英语下册单词表
- 《口腔材料学》教材笔记(12章全)
- 新能源汽车维护与故障诊断-课件-项目二-新能源汽车故障诊断技术
- 穴位注射操作规范及流程图
- 环境监测与污染源在线监控考核试卷
- 油罐安装施工方案
- GB/T 44102-2024跳绳课程学生运动能力测评规范
- GB/T 13305-2024不锈钢中α-相含量测定法
- DL∕T 618-2022 气体绝缘金属封闭开关设备现场交接试验规程
- 多糖铁胶囊的吸收和代谢途径研究
评论
0/150
提交评论