`

关于软件的核心,莫被算法和使用技术完全忽悠了

阅读更多
关于软件的核心,莫被算法和技术完全忽悠了
很多人开发多年,对技术一腔热忱,甚至一些企业,居心叵测的企业,打着“招”最聪明的程序员进行“欺骗”和“误导”,在网络上和乃至社会形成了一种风气,这种风气已经严重影响到软件的开发。

计算机自诞生以来,经历了语言上的成熟,我们逐渐把眼光转向了解决实际问题的问题空间,特别是面向对象的语言诞生以来,因为对象的粒度十分恰当好处,一方面我们很容易把一些语言上的技术添加到面向对象,例如多态,继承等等,另外一方面,也极大地方便我们模块化问题模型(封装和抽象我们的问题),我们越来越认识到,软件的核心是模型,特别是复杂的问题域(Problem Domain)更需要精炼的模型。

在现实的世界,我们知道,对数据的管理能力尤为重要,而算法并非是其中很重要的因素,懂得一些基础算法是对编程有帮助,但是往往非常有限,为了达到软件高可靠性,可重用,易于扩展,易于维护,我们发现,往往不是运算的逻辑实现比较复杂,而是运算逻辑要封装在哪里,放在哪里成了重要的问题。同样的逻辑,放在不同的逻辑水平层次和不同的封装实体(Software Entity)给扩展性,维护性,可测试性产生了巨大的影响,如果做的不好,一起的结果就是带来软件稳定性差,软件成本急剧增加,甚至导致项目失败,公司破产。这就需要我们合理的切分我们的问题,垂直和水平上(参见SoC和AOP),最总归纳出良好的模型,以解决我们所遇见的问题。

关于软件使用到得技术,非常重要,但是不是全部,我们经常看见很多人什么软件都是用过,Hibernate,Spring,Struts,但是往往发现会用和懂技术完全是两回事情,因为他们只知道怎么使用,而不知道为什么使用,导致使用这些技术软件并未给他们带来太多变化。

记得前段时间,一位朋友让我给他们团队的软件做顾问,我看到,他们使用了Spring ORM,每个service方法的代码却都大致如下:

public Result serviceName(…){
    SessionFactory sf = new Configuration().configure().buildSessionFactory();
		//…
}


使用Spring ORM却没有带来一点好处,而且,每调用一次service方法,都会buildSessionFactory(),创建一个新的连接,而他们对Spring ORM的例子却头头是道。这种事严重的只会使用技术框架,却不懂得技术的一个经典例子。

不管是你在开发一款分布式缓存的软件,还是开发一个购物网站,只要你想开发出易于维护,易于扩展,可靠性高的软件,那你就得好好为你的问题域建模。

使用面向对象的语言来开发面向对象的系统,十分不容易,GoF汇总了23个面向对象常用的模式来避免重复的解决类似的问题,但最终还是希望大家自己会使用OO的眼光分析问题,建立模型,因为你遇见的问题和23个经典的问题总是类似有出入的,完全的使用而不加以变化往往引起不好的开发,但如果你学会使用OO眼光抽象和归纳问题,建立合理的模型,那时候,模式还重要吗?

对于模式的学习,请勿流于表面,也请勿认为模式有多神奇,有的人一直使用工厂模式,但是却说不清楚为什么要使用,结果在不应该的场合使用,影响了系统。模式就是对一个常见的问题提出的一个通用的解决方案,常见的问题不至于23个。

别沉浸在百花齐放的使用技术和简单的基础算法中,软件远远不至于如此!
分享到:
评论
3 楼 悲剧了 2011-09-23  
好文,最近在看 松本行弘的程序世界 也在想这些问题
以前上学,一说面向对象就是封装 继承 多态 至于其他的什么也去想了 这跟喊口号没啥区别,对问题本身没有很深入的思考,对软件本身没有去琢磨为什么要这么做,有替代方案吗?完全不知道,就知道增删改查,以为增删改查就是全部
2 楼 redhat 2011-09-23  
好的设计人员最擅长的是处理trade-offs,这是无数“艰难”的决定
1 楼 RayChase 2011-09-23  
同感。
懂设计的人、懂技术的人,应该懂得要把利益最大化的原则,做软件归根结底是要赚钱的。
而且,合适的团队,合适的项目,写合适的代码。
我有一个体会,有的人喜欢写代码的时候留足可扩展性,好端端一个类非得扩展成十几个类的庞大模式,可结果没等扩展项目就黄了。

相关推荐

    电动汽车动力电池管理系统核心算法

    总的来说,电动汽车动力电池管理系统的核心算法是电池安全和效率的保证,涉及到多个复杂的技术环节,需要综合运用多种数学模型和估计算法,并不断进行优化以适应电池性能的变化和使用环境的多样性。

    算法技术手册 - 中文版

    《算法技术手册》内容简介:开发健壮的软件需要高效的算法,然后程序员们往往直至问题发生之时,才会去求助于算法。《算法技术手册》讲解了许多现有的算法,可用于解决各种问题。通过阅读它,可以使您学会如何选择和...

    软件工程师必备算法和设计模式的知识

    在软件开发领域,算法与设计模式是两个至关重要的概念,对于任何希望提升自己技能的软件工程师来说,理解和掌握它们都是必不可少的。算法是解决问题的精确步骤,而设计模式则是解决常见编程问题的经验总结。让我们...

    软件开发技术报告 软件开发技术报告

    在全球定位系统(GPS)的辅助下,...随着技术的不断进步和应用领域的拓展,GPS软件开发技术将继续在提高定位精度和满足用户需求方面发挥重要作用。对于未来的开发者而言,掌握这些核心技术和持续创新将是必备的能力。

    光线跟踪算法技术

    光线跟踪算法技术是一种计算机图形学中用于生成高质量图像的渲染技术,其主要特点是能够计算复杂的光线与场景中物体的相互作用,从而生成接近真实世界的视觉效果。光线跟踪技术的核心原理是从相机的位置发射光线,...

    《实时碰撞检测算法技术》

    《实时碰撞检测算法技术》是一本专注于碰撞检测问题高效解决方案的学术著作,涵盖了设计问题、数学和几何学基础、数据结构、算法以及具体实现等多个方面。该书不仅为读者提供了理论知识,还通过算法、代码和伪代码的...

    哈工大软件学院算法分析与设计考试资料

    最后,这份资料可能还会涵盖一些高级主题,如动态规划在背包问题中的应用、贪心算法在任务调度中的应用、图论在网络流问题中的应用,以及如何使用递归和分治策略解决复杂问题等。 总的来说,《哈工大软件学院算法...

    java算法全卷(包括基本算法和图算法)

    这份资料主要针对使用Java语言进行算法实现的开发者,适用于那些对ANT、EJB、J2EE、JAVA和SPRING等技术栈有了解或兴趣的人群。下面我们将深入探讨这两个核心主题。 一、基本算法 基本算法是所有编程语言的基础,...

    自动排课算法,排课软件,C#排课软件源码,ASP排课软件源码

    排课系统是教育机构管理日常教学活动的关键工具之一,它...以上是关于“自动排课算法”、“排课软件”、“C#排课软件源码”和“ASP排课软件源码”的核心知识点,理解并掌握这些内容有助于开发出高效、实用的排课系统。

    SimpleBGC32- 开源三轴无刷云台算法完全解说

    为了得到更准确的姿态信息,SimpleBGC32采用传感器融合技术,通常结合陀螺仪、加速度计和磁力计的数据。卡尔曼滤波是一种有效的数据融合方法,它可以结合不同传感器的测量结果,减少噪声并提高姿态估计的精度。 五...

    大华股份2014年嵌入式软件、算法类笔试题

    【大华股份2014年嵌入式软件、算法类笔试题】是针对该公司当年招聘过程中的一个重要环节,这是一场集技术性与专业性于一体的考试,旨在考察应聘者在嵌入式系统开发和算法设计方面的综合能力。2014年的笔试题目相比...

    智能汽车竞赛:完全模型组学习软件资源

    总之,《智能汽车竞赛:完全模型组学习软件资源》是一套非常实用的学习资源,可以帮助用户快速掌握智能汽车的核心技术,提高竞赛水平。如果您对智能汽车技术感兴趣,不妨尝试使用该资源,相信您会有意想不到的收获。

    嵌入式系统软件设计中的常用算法 (周航慈 清晰完整版)

    《嵌入式系统软件设计中的常用算法》是周航慈教授的一部力作,该书深入浅出地讲解了在嵌入式系统开发过程中经常使用的各种算法,为读者提供了全面而深入的理解。以下是对该书核心知识点的详细解读: ### 1. 嵌入式...

    RSA算法的C++实现软件

    总的来说,这个“RSA算法的C++实现软件”提供了一个直观的平台,让学习者和使用者能够理解RSA的工作机制,并能在实际场景中进行加密解密和数字签名操作。通过这个软件,我们可以更深入地了解非对称加密的原理,以及...

    贝叶斯网络学习算法――k2算法

    在数据挖掘和机器学习领域,贝叶斯网络被广泛应用于分类预测、诊断系统、决策支持等领域。K2算法是其中一种用于学习贝叶斯网络结构的算法,尤其适用于小到中等规模的数据集。 K2算法,全称为Cowell-Koller-...

    算法大全(包括各种算法及模型的详细介绍)

    《算法大全》是一份详尽的资源,涵盖了各种算法和模型的深度解析,旨在为数学建模以及其他实际问题的解决方案提供理论支持和技术指导。在这个压缩包中,包含了一个名为"算法大全pdf"的文件,我们可以期待它是一个...

    SAR雷达成像点目标仿真——RD算法和CS算法(程序+注释)

    对于SAR雷达图像点目标仿真,通常使用的算法有RD算法和CS算法。RD算法,即Range-Doppler算法,是一种经典的SAR成像算法,它基于距离-多谱勒原理,通过将接收到的回波信号首先在距离域进行匹配滤波,然后在多谱勒域...

    游戏核心算法编程内幕.pdf

    游戏算法电子书 感觉不错 分享给大家 游戏核心算法编程内幕.pdf

    游戏编程核心算法

    非常好的一本关于游戏算法设计的书!

    粒子群算法、遗传算法以及两者的结合的优化算法

    PSO的核心包括两个主要部分:个人最佳(pBest)和全局最佳(gBest),分别记录粒子自身的历史最优位置和整个群体的历史最优位置。通过迭代调整速度和位置,粒子群体趋向于最优解。 遗传算法则是模拟生物进化过程中...

Global site tag (gtag.js) - Google Analytics