热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

关于设计模式的一些看法与思考

最近看完了《designpatternexplained》,本打算单单的从技术角度进行总结的,但是却全然没有头绪。说说自己的粗浅的感悟吧。书里没有把23中设计模式全部罗列出来,摆上类图和源代码,恩,这样的做法在作者看来很傻。作者说,将目标集中在设计模式解决问题本身上“onlytellsuswhattodobutnotw

最近看完了《design pattern explained》,本打算单单的从技术角度进行总结的,但是却全然没有头绪。说说自己的粗浅的感悟吧。

书里没有把23中设计模式全部罗列出来,摆上类图和源代码,恩,这样的做法在作者看来很傻。作者说,将目标集中在设计模式解决问题本身上“only tells us what to do but not when to use and why to do it”。是的,我们需要的应该是思考的过程和方法,而不是前人留给我们的思考结果。

从这个角度讲,设计模式里我们应该学到什么?

设计模式是一组伟大的思想结晶。我们的出发点是应对可能出现和已经出现的需求,并且降低未来的维护难度。我们使用的技术手段是面向对象。

所以,我们要学习:究竟什么是面向对象?为什么要面向对象?怎么面向对象?

面向对象不是封装继承多态。面向对象之父告诉甚至我们,封装继承多态不是他最big idea----message passing 才是!但是message passing也仅仅是看到了表面而已,message passing体现了一个很重要的观点----an object should responsible for themselves!而且这只是管中窥豹,我们还可以看到更多的东西。

为什么要面向对象?面向对象使我们的代码易于书写和维护。不要以为using namespace或者encapsulation就是易于书写和维护,真正的易于书写是指,当我们编码时思考的难度降低了,当需求发生变化的时候我们所做的更改减少了。

怎么面向对象?书中说要从三个角度考虑:conceptual level、specification level和implementation level

从面向过程到面向对象

事物的发展难以摆脱否定之否定原理,程序设计也是如此。面向过程是很自然而然产生的一种设计思路,因为他符合了计算机处理问题的方式。但他有他固有的缺点,其实可以把面向过程看成是高度耦合,松散内聚的面向对象的设计方式。任何两个对象,或者说模块间都可以互相访问对方的成员,模块间分工并不明确,分工的依据是任务的完成顺序。这样一来我们处理问题会很头疼,我们不得不小心翼翼的控制模块不要错误的访问数据。而某个模块任务的完成可能会用到很多其他的模块,当某个模块改动的时候,并不知道这会给其他的模块带来怎么样的负面影响,就像作者说的“Like a snowball that picks up snow as it rolls downhill, a focus on functions leads to a cascade of changes from which it is difficult to escape.”

那高内聚,低耦合的面向对象又有什么好处呢?面向对象里很重要的一个特性是封装,这个封装不止是对数据的封装,还包括对行为,对概念,对实现细节等等的封装,尽可能的叫对象去负责属于他的责任,而外部不需要关心的细节则一概隐藏起来,这似乎更加符合人的思路。这本书里不停的提到《the timeless way of building》,就像建筑一样,房子是用来住的,作为用户我们并不需要知道怎么去盖这所房子,不需要知道房子的骨架----我们只负责住,房子只负责保护我们。

传统面向对象与新观点下的面向对象

书中不停的重复三个观点:

  • Design to interfaces. 封装细节,使使用者和被使用者都能更好的responsible for themselves
  • Favor composition over inheritance. 防止类爆炸,提高内聚。
  • Find what varies and encapsulate it. 封装变化,应对可能的需求变更。

书中余下的篇幅都是在介绍几种设计模式,里面详细应用到了这几个观点。

设计模式

这一部分我不敢太多的赘述,我还没能将这些模式应用到实践中来。稍作粗浅的总结吧。可能有很多错误的理解,希望诸位看官能帮我纠正~

  • the facde pattern:封装复杂的接口或者不需要被外部了解的细节,对外提供一个简单的接口。
  • the adaptar pattern:封装不同的类,使他们具有相同的对外的接口,方便使用。
  • the bridge pattern:概念和实现分离。
  • the abstract factory pattern:由控制器负责对象类型的选择,工厂负责生产相应的对象。隐藏对象合成的细节。
  • the strategy pattern:这个模式很好的实现了两个原则“合成复用”和“封装变化”。将可能出现的变化封装起来,在原对象中组合该封装该变化的对象,靠一个config对象来控制策略的选择。
  • the decorator pattern:这个模式的本质是装饰类的功能,在实现原有类的基础上实现新的功能。
  • the singleton pattern:无须多言,保证只存在一个实例。
  • the observer pattern:说白了就是一群对象盯着消息队列,监听到自己能处理的消息就做出相应的行动。
  • the factory pattern:工厂是抽象的,只定义了子类需要实现什么功能,具体怎么实现,由子类决定。

就谈到这里。

本文地址:http://www.nowamagic.net/librarys/veda/detail/89,欢迎访问原出处。


推荐阅读
  • 本文介绍了如何在多线程环境中实现异步任务的事务控制,确保任务执行的一致性和可靠性。通过使用计数器和异常标记字段,系统能够准确判断所有异步线程的执行结果,并根据结果决定是否回滚或提交事务。 ... [详细]
  • C#设计模式学习笔记:观察者模式解析
    本文将探讨观察者模式的基本概念、应用场景及其在C#中的实现方法。通过借鉴《Head First Design Patterns》和维基百科等资源,详细介绍该模式的工作原理,并提供具体代码示例。 ... [详细]
  • 本文详细介绍了如何在PHP中实现基于概率的随机抽奖功能。通过实例代码,解释了抽奖逻辑、奖品设置及结果统计的方法。适合PHP开发者参考学习。 ... [详细]
  • 本文对宋代词人朱雍的《迷神引》进行翻译和赏析,深入探讨其词作的艺术特色与情感表达。 ... [详细]
  • 本文详细介绍了优化DB2数据库性能的多种方法,涵盖统计信息更新、缓冲池调整、日志缓冲区配置、应用程序堆大小设置、排序堆参数调整、代理程序管理、锁机制优化、活动应用程序限制、页清除程序配置、I/O服务器数量设定以及编入组提交数调整等方面。通过这些技术手段,可以显著提升数据库的运行效率和响应速度。 ... [详细]
  • 利用Selenium与ChromeDriver实现豆瓣网页全屏截图
    本文介绍了一种使用Selenium和ChromeDriver结合Python代码,轻松实现对豆瓣网站进行完整页面截图的方法。该方法不仅简单易行,而且解决了新版Selenium不再支持PhantomJS的问题。 ... [详细]
  • 本文介绍如何使用PHP在WordPress中根据分类类别ID或名称获取所有相关文章,提供详细的方法和代码示例。 ... [详细]
  • 本题来自WC2014,题目编号为BZOJ3435、洛谷P3920和UOJ55。该问题描述了一棵不断生长的带权树及其节点上小精灵之间的友谊关系,要求实时计算每次新增节点后树上所有可能的朋友对数。 ... [详细]
  • 本文详细介绍了如何使用 PHP 接收并处理微信支付的回调结果,确保支付通知能够被正确接收和响应。 ... [详细]
  • 小编给大家分享一下如何移除URL中的index.php,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收 ... [详细]
  • 本文详细介绍了如何在PHP中删除数组中的指定元素、第一个元素和最后一个元素,并提供了具体的代码示例和相关函数的使用说明。 ... [详细]
  • 本文详细解析了汉字‘犐’的基本字义及其在古代文献中的应用,旨在为读者提供全面而深入的理解。 ... [详细]
  • 嵌入式开发环境搭建与文件传输指南
    本文详细介绍了如何为嵌入式应用开发搭建必要的软硬件环境,并提供了通过串口和网线两种方式将文件传输到开发板的具体步骤。适合Linux开发初学者参考。 ... [详细]
  • 解决TensorFlow CPU版本安装中的依赖问题
    本文记录了在安装CPU版本的TensorFlow过程中遇到的依赖问题及解决方案,特别是numpy版本不匹配和动态链接库(DLL)错误。通过详细的步骤说明和专业建议,帮助读者顺利安装并使用TensorFlow。 ... [详细]
  • 本文详细介绍了在XAMPP环境中如何修改Apache和MySQL的默认端口号,并确保WordPress能够正常访问。同时,提供了针对Go语言社区和Golang开发者的相关建议。 ... [详细]
author-avatar
军校招生顾问天使
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有