冒号和他的学生们(连载5)——软件技术

软件技术

借我借我一双慧眼吧,让我把这纷扰看得清清楚楚明明白白真真切切

——《雾里看花》

“现在我们具体介绍一下编程范式。”冒号忽然顿住,隐觉一抹失望从众人脸上掠过,问号更是欲言又止,便鼓励他开口。

问号略显迟疑:“您说编程范式是一种心法,那框架、设计模式还有架构呢?”

“原来如此!”冒号心下了然,“让我说说你们最想听些什么吧。”

众现不信之色。

冒号说道:“一种是具体而实用的,最好能立马解决学习和工作中的问题;一种是时髦而花哨的,管他有用没用,不学点心里就是不踏实。”

众人虽觉此话有些尖刻,细想起来也有几分道理,但老冒明知而不为,不走群众路线,偏去扯什么劳什子的范式——当然,直接谈OOP倒是不错的。

“自以为懂的未必真的懂,自以为不懂的未必真的不懂。” 冒号玩起了玄学,“有些概念和技术即使背得烂熟,甚至用得烂熟,那也不代表真正掌握;有些概念和技术看起来很新奇,却不过是新瓶装旧酒。”

引号颇不服气:“用得烂熟都不算掌握,难不成只有发明概念和技术才算掌握?”

“哈哈,那倒不必。”冒号笑道,“用得烂熟不等于用得恰到好处,能解决问题不等于没有后顾之忧。”

逗号问道:“那掌握的标准是什么?”

“许多应聘者喜欢在简历中言必称精通某某语言、某某技术云云,大多不必面试即知其大言炎炎——倘若真的精通,他当应聘更高的职位。”冒号有感而发却又似不着边际,“任何概念和技术都不是孤立的,如果不能在纵向的时间和横向的联系中找准坐标,便似那群摸象的盲人,各执一端却又自以为是。”

众人心想,老冒虽言辞旦旦却有凿空之嫌,一节课下来,天马行空的扯了不少,真刀真枪的一个也无,该不是只会纸上谈兵吧?

句号紧扣主题:“您为何选择谈编程范式,而不是框架、设计模式还有架构呢?难道它们真如您所说只是时髦而花哨的东西吗?”

“我可没这么说。”冒号矢口否认,“但在弄清一样东西存在的意义之前就随众跟风,早晚会跟丢的。我先问问你们:什么是框架(framework)?它与一般的库(library)和工具包(toolkit)有何不同?”

引号应答:“框架就是一组协同工作的类,它们为特定类型的软件构筑了一个可重用的设计。与库和工具包不同之处在于前者侧重设计重用而后两者侧重代码重用。”

“嗯,有点标准答案的味道。”冒号夸道,“如果吹毛求疵的话,框架并不限于OOP,可以是协同工作的类,也可以是协同工作的函数。一个足够复杂的应用软件开发,为确保快速有效,通常采取的方式是:在宏观管理上选取一些框架以控制整体的结构和流程;在微观实现上利用库和工具包来解决具体的细节问题。框架的意义在于使设计者在特定领域的整体设计上不必重新发明轮子;库和工具包的意义在于使开发者摆脱底层编码,专注具体问题。”

问号提出问题:“框架与库和工具包看起来很相似——都是一些代码集合,都提供一些API(应用编程接口),是什么使得它们不同呢?”

“问得好!”冒号赞言,“框架与工具包最大的差别在截然相反的设计理念上:库和工具包是为程序员带来自由的,框架是为程序员带来约束的。具体地说,库和工具包是为程序员提供武器装备的,框架则利用控制反转(IoC)机制实现对各模块的统一调度从而剥夺了程序员对全局的掌控权,使他们成为手执编程武器、随时听候调遣的士兵。”

叹号苦着脸:“程序员原来就是一小卒子啊!”

“哪个将军不是从小卒做起的?”冒号反问道,“不错,框架是在语言的语法规则之外施加于程序员的又一层枷锁,但没有规矩不成方圆。正如行军打仗,讲究排兵布阵,程序员就是那兵,框架就是那阵。”

句号说:“可不可以这么理解,框架就是一些人——也就是框架设计者,把一个软件开发中最甜的部分啃掉了,剩下部分留给下面的人?”

“从某种意义上说,是这样。”冒号点点头。

时间: 2025-01-03 07:59:13

冒号和他的学生们(连载5)——软件技术的相关文章

冒号和他的学生们程序员提高班纪事系列

冒号和他的学生们(连载27)--接口服务 冒号和他的学生们(连载26)--访问控制 冒号和他的学生们(连载25)--软件应变 冒号和他的学生们(连载24)--对象封装 冒号和他的学生们(连载23)--数据抽象 冒号和他的学生们(连载22)--抽象思维 冒号和他的学生们(连载21)--后台脚本 冒号和他的学生们(连载20)--前台语言 冒号和他的学生们(连载19)--平台语言 冒号和他的学生们(连载18)--系统语言 冒号和他的学生们(连载17)--语言讨论 冒号和他的学生们(连载16)--动态语

冒号和他的学生们(连载9)——泛型范式

泛型范式 算法是脊,数据是肉:思想是鸡,结论是蛋 --题记 冒号重新开讲:"你们会不会经常遇到这种情景:一遍又一遍地写着相似的代码,有心将其归并,却因种种原因无法践行." 逗号心有戚戚焉道:"是啊,有时明明两个函数的实现几乎一模一样的,就因为某些参数不匹配,无法合而为一." "有一种编程范式可以解决这个问题,它打破了不同数据结构之间的壁垒,让你的代码不再臃肿,这--就是泛型编程."冒号的语调和说辞不免令人联想到电视上的减肥广告,"Gen

冒号和他的学生们(连载1)——开班发言

开班发言 授人以鱼不如授人以渔 --古语 冒号开了个程序员提高班,今天迎来了首期学员,他们是问号.句号.逗号.引号和叹号,皆为IT业的新兵.望着台下洋溢着青春与渴望的脸庞,冒号开始了他的开班发言-- 大家好!先自我介绍一下,本人姓冒名号字解之.诸位不必叫我老师,就叫老冒好了.比在座各位痴长几岁,"老"是担得的,"师"却不敢妄言.在下编程多年,自觉小有所成,不敢专藏,特开此班与众共享.虽系一家之言.一孔之见,若能抛砖引玉,又何惧方家之哂?疏谬之处,还望海涵斧正,不致自

冒号和他的学生们(连载2)——首轮提问

首轮提问 敬畏老师莫如敬畏真理 --题记 众人面面相觑,一阵沉默后开始窃窃私语,显然有些不太习惯这种教学方式--笔记本上还没写两个字呢,老师就把球给踢回来了. 冒号也不说话,只是微笑地望着大家. 还是问号打破僵局,开始发问:"老师--" 冒号扬手打断他:"这里没有老师,唯一的老师是你自己.本班的一个特色是:师生角色模糊,大家自主学习,相互启发,教学相长." 问号顿了顿:"老冒--"全班哄堂大笑,"学软件开发,当然得先学语言,计算机语言这

冒号和他的学生们(连载27)——接口服务

27.接口服务 律己宜严,待人宜宽 --<洪应明·菜根谭> 叹号幡然反省:"以前我们做OOP编程时,总是专注于如何利用其他类来解决问题,而较少考虑自己设计的类对其他类的影响." 引号翻开以前的笔记:"前面提过,OOP的世界是民主制的,所有对象都是独立而平等的公民,有权利寻求服务,也有义务提供服务.看来我们是光惦着权利而忘了义务了." 冒号继而提出:"作为服务的提供者,最重要的是讲诚信.首先,服务要有可靠性,不能阳奉阴违--即接口必须履行它的承诺

冒号和他的学生们(连载26)——访问控制

26.访问控制 夫轻诺必寡信,多易必多难 --<老子·德经> 问号提问:"信息隐藏是否专指用private来控制访问?" "这正是我们的下一个焦点."冒号微颔,"访问修饰符(access modifier)除了可以应用于类成员外,在Java和C#中还能应用于整个类.public类自然是公开的,而缺省的类在Java 和C#中分别仅对同一package和assembly开放." 逗号不觉有异:"这有什么讲究吗?" &q

冒号和他的学生们(连载25)——软件应变

25.软件应变 潜其心能观天下之理,定其心能应天下之变 --<吕坤·呻吟语> 第七课刚一开堂,冒号就提了一个问题:"如果把一个Java程序中所有的private关键字换成public,请问该程序还能工作吗?" "应该还能工作,除非--此前不能工作."问号小心翼翼地回答. 冒号接着问:"既然如此,何必费事区分它们呢?" 叹号嘴一撇:"当然是为了信息隐藏啰." 冒号步步紧逼:"隐藏什么信息呢?又为什么要隐藏?

冒号和他的学生们(连载24)——对象封装

24.对象封装 阴阳地理两分张,隐者为阴显者阳 --<玉髓经.曜星论> "用广东话说,真是有型有料又有性格啊!"叹号啧啧连声,"这哪里是在设计软件,分明是在设计心仪的对象嘛." "我们可不就是在谈对象设计吗?"冒号笑着反问,"在OOP的世界里,每位程序员都是造物主.保持热情.专注力和审美情趣,说不定哪一天就像希腊神话里的皮格玛利翁一样,雕塑的美女变活了." "哇,那可就美了!"逗号极尽夸张之调.

冒号和他的学生们(连载23)——数据抽象

23.数据抽象 善张网者引其纲,不一一摄万目而后得 --<韩非子·外储说右下> 问号抢着说:"我知道了:过程抽象的结果是函数,数据抽象的结果应该是数据类型." 冒号首肯:"数据类型与数据运算是程序语言的基本要素,除了内建的类型与运算外,程序语言还提供了用户定义(user-defined)的扩展机制,以提高编程者的效率.正如函数是一些基本运算的复合,自定义类型通常是一些基本类型的复合.不过单纯的复合类型并不是真正意义上的数据抽象,我们关注的是抽象数据类型(ADT).