PHP 杂谈《重构-改善既有代码的设计》之三 重新组织数据


Posted in PHP onApril 09, 2012

思维导图

PHP 杂谈《重构-改善既有代码的设计》之三 重新组织数据
介绍

 
 承接上文的PHP 杂谈《重构-改善既有代码的设计》之 重新组织你的函数继续重构方面的内容。
 
这章主要针对数据的重构。
 
1、争论的声音——直接访问Field还是通过函数(Accessor)访问Field

PHP 杂谈《重构-改善既有代码的设计》之三 重新组织数据

 2.修改Array为Object:当你看到一个Array很像一个数据结构,你可以使用Replace Array with Object,把Array变成一个对象。——数据结构更清晰。

PHP 杂谈《重构-改善既有代码的设计》之三 重新组织数据

 
 
 专业术语
 

accessor:访问者,存储器——在本文翻译为“函数”

dumb:哑

domain class:用以处理业务逻辑

presentation class:用以处理”数据表现形式“

business logic:业务逻辑

unidirectional:单向的

bidirectional:双向的

collection:群集

 Self Encapsulate Field
 
状况:如果Client直接访问值域,会造成Client与值域之间的耦合关系逐渐变得笨拙,那么为这个值域建立取值/设置函数,并且只以这些函数来访问。
 

PHP 杂谈《重构-改善既有代码的设计》之三 重新组织数据

PHP 杂谈《重构-改善既有代码的设计》之三 重新组织数据

PHP 杂谈《重构-改善既有代码的设计》之三 重新组织数据

 

动机:

PHP 杂谈《重构-改善既有代码的设计》之三 重新组织数据

“间接访问变量”:支持更灵活的数据获取方式,如lazy Initialization(意思是只有用到值时,才对它进行初始化。)

“直接访问变量”:代码比较容易阅读,不需要停下来说:“啊,这只是个取值函数”。

       选择:1、代码规范,按照团队中大多数人的做法去做。

 2、个人比较喜欢“直接访问变量”,直到这种方式带来麻烦为止。

 martin(作者)的例子:你想获取superclass中的field,却又想在subclass中将该field改为计算后的值,这就最该使用Self Encapsulate Field。

                         我自己的例子:我一般会把field设置成private,如果外部变量,需要用到此field的时候,我就会用Self Encapsulate Field。或者field的值有变化的时候,用Self Encapsulate Field。


 Replace Data Value with Object
 
 状况:如果你的某个基本类型的field,需要额外的数据和行为,那么将此field变成对象。
 

PHP 杂谈《重构-改善既有代码的设计》之三 重新组织数据

 PHP 杂谈《重构-改善既有代码的设计》之三 重新组织数据

PHP 杂谈《重构-改善既有代码的设计》之三 重新组织数据

 
  动机:
 

PHP 杂谈《重构-改善既有代码的设计》之三 重新组织数据

开发初期,我们也许会使用基本数据类型表示简单的行为。例如:你可能会用一个字符串表示电话号码,但是随后可能会出现电话号码的“格式化“,”验证“,”抽取区号“之类的特殊行为。——这时候我们就需要一个新类。

 
 Replace Array with Object
 
状况:你有一个数组,数组中的元素各自代表不同的东西,那么以对象替换数组,对于数组中的每个元素,以一个值域表示之。
 

PHP 杂谈《重构-改善既有代码的设计》之三 重新组织数据

PHP 杂谈《重构-改善既有代码的设计》之三 重新组织数据

PHP 杂谈《重构-改善既有代码的设计》之三 重新组织数据

 动机:

PHP 杂谈《重构-改善既有代码的设计》之三 重新组织数据

数组常用于一组相似对象。如果数组中的元素不同,很难明白数组中的第一个元素是人名这样的约定。对象就不同了,可以通过值域名称和函数名称传达这样的信息。——这样无须死记,无须注释。

 Encapsulate Field
 
状况:如果你的class中有一个public值域,那么将它声明为pirvate,并提供相应的访问函数。

PHP 杂谈《重构-改善既有代码的设计》之三 重新组织数据

PHP 杂谈《重构-改善既有代码的设计》之三 重新组织数据

PHP 杂谈《重构-改善既有代码的设计》之三 重新组织数据

 动机:

PHP 杂谈《重构-改善既有代码的设计》之三 重新组织数据

面向对象的原则之一就是封装(Encapsulate)或者称为”数据隐藏“。按照此原测,你绝不应该把数据声明为public。

——public 数据被看成是一种不好的做法。

——如果封装了,代码的修改就会比较简单,因为都集中在一个地方。

 一个函数除了访问函数(getting/setting)外,不提供其他行为,它终究只是一个dumb class(哑类)。这类class不能获得对象技术的优势。——解决哑类的方法是Move Method轻快的将它们移到新对象去。
 
 conclusion
 
我希望能把我理解的东西与大家分享,欢迎大家提出宝贵意见。
PHP 相关文章推荐
一个PHP模板,主要想体现一下思路
Dec 25 PHP
用PHP实现图象锐化代码
Jun 14 PHP
php 正则匹配函数体
Aug 25 PHP
php cli模式学习(PHP命令行模式)
Jun 03 PHP
解析php中heredoc的使用方法
Jun 17 PHP
使用淘宝IP库获取用户ip地理位置
Oct 27 PHP
Linux下安装oracle客户端并配置php5.3
Oct 12 PHP
服务器上配置PHP运行环境教程
Feb 12 PHP
PHP设计模式之简单投诉页面实例
Feb 24 PHP
php正则表达式基本知识与应用详解【经典教程】
Apr 17 PHP
PHP后台备份MySQL数据库的源码实例
Mar 18 PHP
php设计模式之适配器模式实例分析【星际争霸游戏案例】
Apr 07 PHP
PHP 杂谈《重构-改善既有代码的设计》之一 重新组织你的函数
Apr 09 #PHP
PHP乱码问题,UTF-8乱码常见问题小结
Apr 09 #PHP
PHP中return 和 exit 、break和contiue 区别与用法
Apr 09 #PHP
php 的加密函数 md5,crypt,base64_encode 等使用介绍
Apr 09 #PHP
PHP压缩html网页代码(清除空格,换行符,制表符,注释标记)
Apr 02 #PHP
PHP文件注释标记及规范小结
Apr 01 #PHP
用PHP读取超大文件的实例代码
Apr 01 #PHP
You might like
php 格式化数字的时候注意数字的范围
2010/04/13 PHP
PHP 使用pcntl和libevent 实现Timer功能
2013/10/27 PHP
Javascript操作select方法大全[新增、修改、删除、选中、清空、判断存在等]
2008/09/26 Javascript
html数组字符串拼接的最快方法
2009/09/16 Javascript
基于jquery的大众点评,分类导航实现代码
2011/08/23 Javascript
js实现有时间限制消失的图片方法
2015/02/27 Javascript
javascript实现英文首字母大写
2015/04/23 Javascript
js字符串操作方法实例分析
2015/05/06 Javascript
详解javascript中的事件处理
2015/11/06 Javascript
基于JS实现EOS隐藏错误提示层代码
2016/04/25 Javascript
JS实现的打字机效果完整实例
2016/06/20 Javascript
Node.js readline模块与util模块的使用
2018/03/01 Javascript
微信小程序支付前端源码
2018/08/29 Javascript
微信小程序日历/日期选择插件使用方法详解
2018/12/28 Javascript
[01:24:34]2014 DOTA2华西杯精英邀请赛5 24 DK VS LGD
2014/05/25 DOTA
[54:33]2018DOTA2亚洲邀请赛小组赛 A组加赛 Liquid vs Optic
2018/04/03 DOTA
python基础_文件操作实现全文或单行替换的方法
2017/09/04 Python
python3.5 tkinter实现页面跳转
2018/01/30 Python
Python wxpython模块响应鼠标拖动事件操作示例
2018/08/23 Python
python 实现批量xls文件转csv文件的方法
2018/10/23 Python
python基于itchat模块实现微信防撤回
2019/04/29 Python
Django REST框架创建一个简单的Api实例讲解
2019/11/05 Python
python NumPy ndarray二维数组 按照行列求平均实例
2019/11/26 Python
Pycharm中安装Pygal并使用Pygal模拟掷骰子(推荐)
2020/04/08 Python
Android笔试题总结
2014/11/29 面试题
创先争优制度
2014/01/21 职场文书
医药营销个人求职信范文
2014/02/07 职场文书
优秀学生党员先进事迹材料
2014/05/29 职场文书
计算机应用应届生求职信
2014/07/12 职场文书
社区精神文明建设汇报材料
2014/08/17 职场文书
网上祭先烈心得体会
2014/09/01 职场文书
房屋租赁合同补充协议
2014/10/11 职场文书
工作失职检讨书500字
2014/10/17 职场文书
幼儿园校车安全责任书
2015/05/08 职场文书
2015小学音乐教师个人工作总结
2015/07/21 职场文书
再次探讨go实现无限 buffer 的 channel方法
2021/06/13 Golang