资料介绍
过度封装是程序员最容易犯的错, 因为是否过度并没有固定的数值标准, 只能是有经验的程序员基于科学的判断。过度封装的危害十分严重, 所以必须重视, 并且极力避免。
首先, 什么是“过度封装”? 我们知道, 计算机科学领域最称为经典也是最强大的思想便是递归, 分而治之。但是, 递归本身最重要的因素是: 结束条件。 一生二, 二生三, 三生万物, 总要有终止的条件吧? 不然一辆车不停地急驰, 你怎样上车?
新手程序员, 特别是非科班出身的文科程序员, 最容易犯了过度封装的错误的原因就是不知道何时适可而止, 脑筋往往不断地分解分解再分解问题, 最后, 你看到的就是这个调用那个, 那个引用这个, 乱七八糟毫无头绪, 三两行代码的函数比比皆是, 自以为封装抽象, 其实是拿捏不好这个度。
一旦过度封装, 直接的危害往往是写了无数行代码, 封装了N多个类, 就是看不出一个完整的功能, 因为分裂起来收不住。即使最终把功能实现了, 代码维护性也让人不忍直视。
如何判断是否过度封装? 如何避免过度封装? 我认为, 只要掌握了一个原则, 时刻以这个原则为准绳, 那便几乎不会犯过度封装的错误。
这个原则便是“直观优先”原则, 代码逻辑以直观为最优先的原则, 其它的原则均低于此原则, 即使有一百个考虑, 如果违反了直观原则, 都必须放弃掉而优先保证直观原则。
举一个例子:
function closeDialog() { login.close(); message.close(); 。。.close(); } var action = { close: function () { closeDialog(); }, backout: function () { if (BACKOUT_ID) { 。。. } } }; $(document).on(’click‘, function (e){ var $that = $(e.target); for ( var k in action) { if ( $that.hasClass(’action-‘+k) ) { action[k].call(e.target); } } });
这样的代码就是过度封装的经典体现!
首先, closeDialog() 这个函数不应该存在, 而应该被展开, 因为函数只被调用一次, 而且没有逻辑上的独立性的必要。
其次, 上面的函数通过跳转表的方式来逃避直接的函数调用, 这是对跳转表技术的极大滥用! if-else 加函数调用是最直观的分支跳转方式, 完全没有必要在这个例子里使用跳转表技术。
先解释一下什么是跳转表技术, 这是一个非常古老而基础的计算机编程领域的技术。跳转表包含很多层含义, 简单的说, 就是将逻辑代码块放到一个索引表中, 代码编写过程通过传递索引项来最终调用相应的逻辑代码块(因为多处引用)。
第一次听到或者见到跳转表技术的程序员的心情, 如果你想体验的话, 你想想当你写了无数的 if-else 之后, 你发现了 switch-case 时的心情, 或者是你第一次听到函数指针这个事物时的心情。
但是, 像 js 之类高级语言, 已经把跳转表技术, 直接融合到了语言的语法本身, 如类(class)。 你不需要实现自己的跳转表技术, 你只需要用好语言本身的特性即可。
所以, 上面的代码应该改成:
$(document).on(’click‘, function (e){ var $that = $(e.target); if ( $that.hasClass(’action-close‘) ) { login.close(); message.close(); 。。.close(); } if ( $that.hasClass(’action-backout‘) ) { if (BACKOUT_ID) { 。。. } } });
这是最直观, 最正常, 人人都应该写成这样的代码。如果你还想显式地使用查找表技术以体现自己牛逼, 我是说, 如果你真想装逼的话, 你可以这样写:
var action = { close: function () { login.close(); message.close(); 。。.close(); }, backout: function () { if (BACKOUT_ID) { 。。. } } }; $(document).on(’click‘, function (e){ var $that = $(e.target); var func_name = $(that).attr(’action‘); if(func_name && action[func_name]){ action[func_name](); } });
如果都这样写了, 那和直接在 html 标签里写 onclick 属性有什么区别? 难道通过 class 绑定事件就高级, 写 onclick 指明回调函数的名字就不高级了?
所以我劝你最好不要装逼也别装傻, 乖乖地有理有据有逻辑地写代码, 让代码的逻辑直观起来, 不要过度封装。如果你内心封装的欲望太强的话, 那我劝你学学 Go 语言, 把自己的思想强加到一种自己新发明的语言上来(我估计你没那种本事)。不然, 直观优先, 不要过度封装。
- 程序员表白程序 0次下载
- 程序员的浪漫《Rice DIY设计》 8次下载
- 数字万用表8845A/8846A程序员手册 19次下载
- 成为一个程序员需要准备那些东西 1次下载
- 程序员如何规划自己的成长之路 0次下载
- 程序员必备专用单词快来学习吧! 22次下载
- 16位MCU和DSC程序员参考手册.免费下载.pdf 45次下载
- 程序员需要学什么,微软资深程序员学习手册面试宝典资料 30次下载
- 程序员的数学-结城浩 0次下载
- 程序员羊皮卷下载版(程序员必备) 0次下载
- Turbo C高级程序员编程指南_陈捍东 0次下载
- 程序员2011第5期 0次下载
- 程序员2011第9期 0次下载
- 程序员2011第11期 0次下载
- ADO程序员指南 3次下载
- 5款程序员最佳的代码比较工具 3429次阅读
- 六款程序员必看的前端在线开发工具 2504次阅读
- 盘点Java程序员不能错过的7个基本框架,完美构建复杂应用 2767次阅读
- 程序员为什么记不住所有的代码如何解决这个问题 6908次阅读
- 程序员需要知道的那些定理和法则 2872次阅读
- 程序员值得一看的9本学习算法经典书籍 3.9w次阅读
- 华为资深工程师:程序员与码农的差异在哪? 3461次阅读
- 一个电子发烧友的程序员成长之路 6569次阅读
- 对技术的执着和美的追求变成了程序员的“诗和远方” 1880次阅读
- mac使用者心理剖析和程序员必备软件推荐 6088次阅读
- 数据显示:中国程序员是世界上最牛的程序员 523次阅读
- 码农和程序员之间就在这5个关键点! 540次阅读
- 我们对技术的依赖有多强?程序员为何关注它? 925次阅读
- 程序员真正的价值是什么? 1574次阅读
- 嵌入式程序员需要了解的几个问题 1211次阅读
下载排行
本周
- 1储能电源市场分析
- 7.99 MB | 6次下载 | 免费
- 2储能电源市场分析报告
- 2.61 MB | 6次下载 | 免费
- 3具有DCS-Control™ 功能的 3V 到 17V 0.5A 降压转换器TPS6217x-Q1数据表
- 3.17MB | 1次下载 | 免费
- 4磁环电感定制时应该注意什么
- 0.32 MB | 1次下载 | 免费
- 5高效降压转换器 MicroSiP™模块TPS82084 (2-A)/TPS82085 (3-A)数据表
- 1.75MB | 次下载 | 免费
- 6采用DSBGA封装的LMR24210 42V 输入电压、2A 降压稳压器数据表
- 1.82MB | 次下载 | 免费
- 7采用增强型Hotrod™ QFN封装的TPSM560R6 60V输入、1V至6V输出、600mA 电源模块 数据表
- 2.06MB | 次下载 | 免费
- 8具有外部参考输入的低引脚数、低VIN(3.0伏至5.5伏)同步降压DC-TO-DC控制器数据表
- 1.18MB | 次下载 | 免费
本月
- 1ES9038PRO解码芯片的电路原理图介绍
- 0.25 MB | 35次下载 | 5 积分
- 2UHD智能显示SoC VS680产品简介
- 0.46 MB | 11次下载 | 免费
- 3STM32国内外发展现状
- 1.15 MB | 11次下载 | 免费
- 4ATmega8芯片中文手册
- 2.45 MB | 8次下载 | 1 积分
- 5TDK电容器产品指南
- 11.88 MB | 7次下载 | 1 积分
- 616A 输出电流,高可靠、高效率 同步降压转换器PCD3201产品手册
- 0.47 MB | 6次下载 | 免费
- 7传感芯片选型指南
- 3.60 MB | 6次下载 | 免费
- 8储能电源市场分析
- 7.99 MB | 6次下载 | 免费
总榜
- 1matlab软件下载入口
- 未知 | 935086次下载 | 免费
- 2开源硬件-PMP21529.1-4 开关降压/升压双向直流/直流转换器 PCB layout 设计
- 1.48MB | 420050次下载 | 免费
- 3Altium DXP2002下载入口
- 未知 | 233068次下载 | 免费
- 4电路仿真软件multisim 10.0免费下载
- 340992 | 191316次下载 | 免费
- 5十天学会AVR单片机与C语言视频教程 下载
- 158M | 183316次下载 | 免费
- 6labview8.5下载
- 未知 | 81567次下载 | 免费
- 7Keil工具MDK-Arm免费下载
- 0.02 MB | 73786次下载 | 免费
- 8NI LabVIEW中实现3D视觉的工具和技术
- 未知 | 70088次下载 | 免费
评论
查看更多