伴随开发人员成长的问题:工程重要,还是算法重要?细节重要,还是架构重要?

2024-01-17 11:48

本文主要是介绍伴随开发人员成长的问题:工程重要,还是算法重要?细节重要,还是架构重要?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

2005年12月04日 22:07:00

为了考虑一段代码中的字符串处理效率问题,我写了一个测试程序来检测字符串引用,然后把它贴在delphibbs里(http://www.delphibbs.com/delphibbs/dispq.asp?lid=1220572)。随后这引起了对软件工程和开发技巧的争论。下面的文字很大程度上代表了我当时(2002年中)对开发技术、技巧的观点,我想这与现在的很多开发人员的观点是一致的:

========================

说实在的,现在越来越多的人员都在说要重工程,而不要重算法,不要重技巧;陷于程序的枝节,不如跳出来考虑总体结构。

看起来说得很对,但问题是,为什么到现在M$的编译器的速度都比Borland的慢?M$在这上面追了这么多年,什么样的软件工程没搞过,却怎么还是比人家的慢?

现在个人机越来越高档,对于个人而言,好象是永远也不用到CPU极限一样。但是,服务器呢?成千上万个人在用,服务器端的软件不讲求效率和性能,面临的可能就是不断地找机房管理员重启服务器!

在大谈软件工程的时代,我来追求一两行代码的性能,可能是老土,但如果做服务器程序的人,没有土一点的思想,不明白编译器的细节,可能是行不通的。

早些日子一个知名的程序员(我的同事)说他的程序象美国造的军用匕首,精巧好用,科技含量十足,而另一个程序员写的程序象前苏联的坦克,耗油、声音大但用三十年不会返修,连螺丝钉都不会掉一个。

我就说,前者适合做个人工具软件,后者适合做服务器端..

========================

基本上,即使是现在,我仍然不会去否定这种"出自程序员"的观点。但站在另外的角度,例如"软件工程的实践者",我却在思考"语言只是工具"以及"语言只是工程中的细节"这样的问题;或者站在架构师的角度,开始思考"如果有性能需求,那么就在技术细部做处理"、"不要把‘新技术'与‘好方法'给等同起来"这样的问题。

我开始否认技术与技巧,是与承认它们、思考它们同时并进的。在《Delphi源代码分析》的前言里头,我就写过:"通常,如果你发现‘必须使用技巧来解决问题',那么你应当考虑‘是否方案设计错误'",而写这句话的同时,我正在自相矛盾地研究着Delphi内部的细节与技巧。

而现在,我一面在如同2002年持上述现点一样地用技术和技巧来实现一些架构的细部,同时又在实践着我在《大道至简》中写过的言论:语言只是工具。

我们对于事物的认识总是渐进的,你不能指望孔子、老子、庄子这些先贤们在二、三十岁的时候就有如今我们所知所见的思想深度,因而你也不能期望没有软件开发实践的新手们去相信你对工程和架构的理念。如同我在三年前固执于效率、技巧与细节那样,我们总能看到开发人员最正常、最真实以及最可爱的一面:持着与细致。

然而我现在的观点是:"如何做"只是手段问题,"做什么",才应当是关注的焦点。

因而我还想问的是:为什么到现在M$的编译器还是比Borland的慢,然而VS.NET已经绝对占领了未来Windows平台上开发的市场?



Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=543590


这篇关于伴随开发人员成长的问题:工程重要,还是算法重要?细节重要,还是架构重要?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/615936

相关文章

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

mybatis的整体架构

mybatis的整体架构分为三层: 1.基础支持层 该层包括:数据源模块、事务管理模块、缓存模块、Binding模块、反射模块、类型转换模块、日志模块、资源加载模块、解析器模块 2.核心处理层 该层包括:配置解析、参数映射、SQL解析、SQL执行、结果集映射、插件 3.接口层 该层包括:SqlSession 基础支持层 该层保护mybatis的基础模块,它们为核心处理层提供了良好的支撑。

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

百度/小米/滴滴/京东,中台架构比较

小米中台建设实践 01 小米的三大中台建设:业务+数据+技术 业务中台--从业务说起 在中台建设中,需要规范化的服务接口、一致整合化的数据、容器化的技术组件以及弹性的基础设施。并结合业务情况,判定是否真的需要中台。 小米参考了业界优秀的案例包括移动中台、数据中台、业务中台、技术中台等,再结合其业务发展历程及业务现状,整理了中台架构的核心方法论,一是企业如何共享服务,二是如何为业务提供便利。

好题——hdu2522(小数问题:求1/n的第一个循环节)

好喜欢这题,第一次做小数问题,一开始真心没思路,然后参考了网上的一些资料。 知识点***********************************无限不循环小数即无理数,不能写作两整数之比*****************************(一开始没想到,小学没学好) 此题1/n肯定是一个有限循环小数,了解这些后就能做此题了。 按照除法的机制,用一个函数表示出来就可以了,代码如下

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

康拓展开(hash算法中会用到)

康拓展开是一个全排列到一个自然数的双射(也就是某个全排列与某个自然数一一对应) 公式: X=a[n]*(n-1)!+a[n-1]*(n-2)!+...+a[i]*(i-1)!+...+a[1]*0! 其中,a[i]为整数,并且0<=a[i]<i,1<=i<=n。(a[i]在不同应用中的含义不同); 典型应用: 计算当前排列在所有由小到大全排列中的顺序,也就是说求当前排列是第

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖

【数据结构】——原来排序算法搞懂这些就行,轻松拿捏

前言:快速排序的实现最重要的是找基准值,下面让我们来了解如何实现找基准值 基准值的注释:在快排的过程中,每一次我们要取一个元素作为枢纽值,以这个数字来将序列划分为两部分。 在此我们采用三数取中法,也就是取左端、中间、右端三个数,然后进行排序,将中间数作为枢纽值。 快速排序实现主框架: //快速排序 void QuickSort(int* arr, int left, int rig