`

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

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

计算机自诞生以来,经历了语言上的成熟,我们逐渐把眼光转向了解决实际问题的问题空间,特别是面向对象的语言诞生以来,因为对象的粒度十分恰当好处,一方面我们很容易把一些语言上的技术添加到面向对象,例如多态,继承等等,另外一方面,也极大地方便我们模块化问题模型(封装和抽象我们的问题),我们越来越认识到,软件的核心是模型,特别是复杂的问题域(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  
同感。
懂设计的人、懂技术的人,应该懂得要把利益最大化的原则,做软件归根结底是要赚钱的。
而且,合适的团队,合适的项目,写合适的代码。
我有一个体会,有的人喜欢写代码的时候留足可扩展性,好端端一个类非得扩展成十几个类的庞大模式,可结果没等扩展项目就黄了。

相关推荐

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

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

    算法技术手册 - 中文版

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

    光线跟踪算法技术

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

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

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

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

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

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

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

    RSA算法的C++实现软件

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

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

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

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

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

    可视化图论算法软件

    软件可能运用了Activity On Node (AON)或Activity On Arrow (AOA)模型来识别关键路径,例如使用拓扑排序和增广路径方法。 5. **最大流算法**:这用于在网络中寻找最大的流量,如Ford-Fulkerson或Edmonds-Karp算法。...

    基于python的RSA加密算法软件设计与实现.docx

    RSA 加密算法的核心思想是基于大数分解的问题,通过使用大素数的乘积来生成公钥和私钥,然后使用公钥来加密数据,而私钥来解密数据。这种算法的安全性主要来自于大素数分解的难度。 在 python 中实现 RSA 加密算法...

    游戏编程核心算法

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

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

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

    java国密算法实现

    总的来说,Java国密算法实现涉及了椭圆曲线加密和哈希函数两大核心概念,通过合理运用这些算法,可以构建安全可靠的加密通信和数据保护系统。在具体编程时,需要对算法原理有深入理解,并熟练掌握相关库的使用,以...

    wK算法算法处理RADARSAT-1数据_share

    3. **Matlab** - 提示处理过程可能使用了Matlab软件,这是一种广泛应用于数值计算、数据分析和算法开发的环境,适合进行图像处理和信号分析。 4. **数据处理** - 指出这个项目主要关注的是数据的预处理、解析和后...

    VC++霍夫曼算法压缩小软件

    总结来说,"VC++霍夫曼算法压缩小软件"是一款利用霍夫曼编码技术实现数据压缩的工具,结合了VC++的编程优势和MFC的图形用户界面支持。它不仅展示了霍夫曼编码的实际应用,也提供了学习高级编程和数据压缩技术的实例...

    算法 第4版.pdf

    《算法》第四版是图灵丛书中的经典之作,专注于阐述算法和数据结构的核心概念,是计算机科学和技术领域不可或缺的学习资源。这本书以清晰易懂的方式,深入浅出地讲解了编程中涉及的各种算法和数据结构,适合初学者和...

    数据结构算法动态演示CAI软件的实现.pdf

    数据结构与算法是计算机科学的核心,它们是程序设计、软件开发的基础,与计算机硬件和软件紧密相关。数据结构的研究包括但不限于编码理论、存储装置和存取方法,关系到编译程序、操作系统、数据库系统以及大型应用...

    Weka中各种分类算法和聚类算法集成

    本工具包集成了Weka中最新的分类和聚类算法,将其打包成jar包,方便java开发者调用

Global site tag (gtag.js) - Google Analytics