软件工程真的是一门什么用都没有的学科么?

软件工程真的是一门什么用都没有的学科么?

-----读《构建之法》有感

楔子

我很惭愧,构建之法这本书已经出版四五年了,我之前却未曾涉猎,还是在通过组织长沙.net技术社区之后,才因为因缘际遇有幸认识邹欣邹老师之后,才了解和阅读了这本书。这是一本非常不错的软件工程学著作,事实上应该值得IT企业中不同岗位的从业者都来读,而不仅仅只是软件工程师或软件设计师来读。  


回到10多年前,当时我有幸就读于位于湖南湘中小城娄底的人文科技学院,那是湖南众多二本院校中排名较后的普通学府,并且我就读的专业是数学系下的学科,信息与计算科学专业,这是一个数学和计算机的边缘学科。事实上呢,其实当时班上绝大多数人都是调剂生,我是为数不多的一志愿录取吧,因为对计算机感兴趣,高中数学成绩太差,想在进一步学习数学才选了这个专业,当然,实际上入学后我的数学成绩依然很差,这就是后话了。 


由于这个专业的教授队伍本身就是数学教授为主,因此开设了许多数学加计算机的课程,那些数学课程令我头大,屡屡挂科,但是那些计算机学科的课程却令我痴迷,并最终让我选择了IT行业,并在这条道路上已经迈过来十个年头,甚至已经决定把他当做终生职业来奋斗。这些课程中,包括了软件工程,当时使用的教材来自于清华大学,那本在我这种阅读爱好者看来浅显易懂的软件工程基础书,在我的同学眼中却仿佛看天书。在书中,作者以比较容易理解的角度简单介绍了软件工程的前因后果和本质,让我觉得如获至宝,经常手不释卷,一直到大学毕业后三年,我都保留了这本书,并时常翻阅。

什么叫做软件工程?

不知不觉从业十年,再回过头来看这门学科,我觉得我有了不同的体会。软件工程究竟是什么?应该说时至今日,许多资深从业者都不能理解,这也证明为什么有的院校的软件工程课,最终应学生的要求改成了学习JAVA视频教学的原因吧。作为一名十年经验的开发者,我不打算引用原文中的话来说明究竟什么是软件工程,而是说一下自己的理解,我认为软件工程实际上定义了IT公司的管理流程,设计理念,企业架构的方方面面。在这个知识大爆炸的时代,计算机领域的书籍非常多,大部分都是偏重于介绍开发者技能提高的书籍,大概可以成为技能书,通过阅读这些技能书,开发者只需花较短的时间就能快速的掌握作者多年学习的收获,并快速的成长,进而实现自己收入的大幅度提高。软件工程所介绍的内容,在某些读者眼里,看起来就像天书昏昏欲睡,尤其是那些UML图和设计理念,在某些开发者眼里认为,就是浪费公司的人力财力和时间,于是有人说软件工程其实什么用都没有。 


我觉得软件工程更像是心法,技术不好的时候,心法通则技术通,技术好了,更需要读心法,这样可以让你的念头通达,格局透彻。软件工程,或许并不像一门工程学,更像两种东西的融合,一个是软件管理学,一个是软件设计学,更像是从更高的维度来看待软件和软件公司的全生命周期,又从更微观的角度来介绍如何优雅的设计一个软件。这也大概是邹老师的杰作,《构建之法》的标题,取的是构建,而不是架构的原因吧。 


构建是什么?在最开始听到这个名词时,我以为是build,我甚至觉得构建一个软件,不就是开发集成环境中的一个按钮么?难道这本书谈的是编译原理?然而我错了,这本书实际上是build一套企业管理制度和文化,build一套切实可行的软件技术体系,正是讲述如何优雅的build一家能够持久生存的IT公司,用现在的主流说法,就是打造优秀IT企业的最佳实践方法吧。 


当然,来到9102年的今天IT公司似乎已经成为一个令人不适的名词,在大家的眼中,仿佛言不离互联网公司,似乎一家公司自称是IT公司就自降身价一般。然而,互联网公司难道不是IT公司么?留给读者们评说吧。

 

那些所谓的最佳实践

说到最佳实践,目前我也在一家互联网公司,也有幸接触了一些比较大的圈子,那就是中国的MVP们,他们是微软最有价值的技术专家,这些专家们都对技术充满了无限的追求、并积累了丰富的知识体系,从他们的交流沟通过程以及我自己平时的积累,我遇到了以下几种常见,却不一定正确的最佳实践。 


1、设计优先 
互联网公司常用的模式之一,就是设计和用户体验优先,在这种理念中,认为用户体验是第一生产力,技术是第二生产力。先把面子做好,再把产品做好。 


2,架构优先 
这种理念认为,软件架构体系是决定软件生死命脉的关键因素。往往容易变成架构师优先,往往会招一位优秀的架构师,然后来组建他的核心班底,再变成一家技术优先的企业。真的是最佳实践么?谁吃过苦谁自己明白。 


3,中台优先 
阿里巴巴的实践告诉我们,要重中台,轻前台,一切以业务流转为目标。但是真的是每家企业的最佳实践么? 


4,数据优先 
这种理念认为,数据是第一生产力,一切业务都是数据。在前几年的DT时代,就是这么鼓吹数据优先,然后各种大数据平台层出不穷,但是,往往做成了多数据,数据大(意思是指那些看起来大,却不符合5v特点的数据),却很少有必要做成大数据,大数据也属于被国人玩坏的概念吧?。

 

论构建的重要性

可以说,中国人大概是最善于玩文字游戏的,那些来自成功企业的所谓最佳实践,依然得依据企业的实际情况出发才能产生效果。 


我认为,或许对IT企业来说,最佳实践应该依然是,构建优先,即作为一家软件公司,野蛮生长到最终,依然是构建符合企业实际的IT企业管理体系。例如阿里巴巴,不仅汇聚了全国最顶级的技术人才,更是建立了一套最为完善的IT管理体系,最终才得以让IT技术促进企业得以快速发展。 


必须承认,在中国有许多业务优先的公司,其实并不能理解IT公司与传统公司的区别,总是用自己片面的理解认为,公司什么都缺,缺的只是一个程序员或几个程序员,但是,真的是这样么?没有,哪怕有幸被你招到了一位能独挑大梁的优秀程序员,往往也会由于与企业文化和管理理念极度的不适应而离去。 


在互联网概念已经深入人心的今天,从某种意义上讲,或许对于企业,只要掌握了合适的时机加上一些机遇,也许总是能获得成功。但是,真的能存活超过十年的时间,并保持持续的增长么?在偌大的中国,近些年以来有许多优秀的企业凭借优秀的产品获得了短期的成功,却深刻反映出中国经济发展全靠吃人口红利的客观事实。 


尤其是那些看起来短期依靠员工的创新能力获得快速发展的中小型或者独角兽企业,越是容易因为创新能力枯竭而最终内卷化。每家公司都有机会火五分钟,但是有的公司大概只能火那么几分钟。 


任何IT公司,撇开软件管理之道谈纯粹的技术实现或产品输出,或许都不过是一瞬间的爆发,越是看起来成功的优秀的互联网公司越是必须基于软件工程学的理论出发,建立一套切实可行,持续迭代的管理体系才能获得长久的生命力。 


但是,哪怕有了构建之法,又该如何打破中国IT企业平均寿命不过2.8年的客观事实呢?我想我还是好好搬砖吧。。

640?wx_fmt=jpeg


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/316730.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Ball Dropping

Ball Dropping 题意&#xff1a; 求&#xff1f;的具体长度 题解&#xff1a; 算一算就出来了 代码&#xff1a; #include<bits/stdc.h> using namespace std; int main(){double r,a,b,h;cin>>r>>a>>b>>h;if(2*r<b&&2*r<…

[WF2011] MachineWorks(李超树优化dp)

[WF2011]MachineWorksproblem BZOJ3963 solution 来得比较快的是&#xff0c;直接设 dpi,j:dp_{i,j}:dpi,j​: 考虑第 jjj 天换购 iii 机器。 但是马上注意到天数是 1e91e91e9 级别的&#xff0c;而机器是 1e51e51e5 级别。 稍微想想&#xff0c;就能知道&#xff0c;因为…

P3644 [APIO2015]八邻旁之桥(中位数、堆)

前言 卡了很长时间的一个题。 一开始 k1 的关键性质把握就跑偏了&#xff0c;后面基本在硬做… 关键就是一直把每个人当成一条线段作为整体在看&#xff0c;使问题很复杂… 最后用 three-pointers 磕磕绊绊搞出来了。 但是根本不用&#xff01; 解析 这题关键就在于&#xf…

尝试:Script Lab,开发模式之知识储备//SL02

前期00&#xff1a;深度&#xff1a;从 Office 365 新图标来看微软背后的设计新理念前期01&#xff1a;尝试&#xff1a;Script Lab&#xff0c;快速 Office 365 开发工具 //SL01本期02&#xff1a;尝试&#xff1a;Script Lab&#xff0c;开发模式之知识储备 //SL02项目特点适…

【学习笔记】Miller-Rabin(米勒-拉宾)素性测试,附常用表

TOC 素性测试是检验一个给定的整数是否为素数的测试。 最简单的就是用 n\sqrt{n}n​ 以内的数去试除。这是确定性的算法&#xff0c;即能准确知道 nnn 是否为质数。 但今天学习的是一种随机算法。 Fermat 小定理 如果 ppp 是一个质数&#xff0c;且 a%p≠0a\%p≠0a%p​0…

Hash Function

Hash Function 文章目录题意&#xff1a;题解&#xff1a;代码NTT代码FFT代码题意&#xff1a; 给定n个互不相同的数&#xff0c;找一个最小的模域&#xff0c;使得它们在这个模域下互不相同。n<5e5 题解&#xff1a; 考虑两个数a和b&#xff0c;a与b模m余数相同&#xf…

P5321 [BJOI2019]送别(LCT)

Foreword\text{Foreword}Foreword 肝了一下午一晚上的码农题… &#xff08;主要就是在 debug&#xff0c;LCT 太难 de 了…&#xff09; 感谢 M_sea&#xff0c;在调无可调认为LCT会不会不可做时&#xff0c;我看到了他的题解&#xff0c;几乎一样的思路&#xff0c;给了我继…

WebApi网关之Bumblebee和Ocelot性能对比

Bumblebee是基于.net core 2.1开发的WebApi网关组件&#xff0c;由于Bumblebee所追求的轻量化和性能&#xff0c;所以它并没有像Ocelot那样从asp.net core上进行扩展&#xff1b;而是构建在BeetleX.FastHttpApi之上&#xff0c;主要原因BeetleX.FastHttpApi有着更轻量化和高性能…

【无码专区11】异或2(结论 / 推式子 + 哈希hash + 大整数高精度 加减乘除重载考察)

本题已自我实现。但仍归于无码专区 problem 求 ∑i1n−1i⨁(n−i)\sum_{i1}^{n-1}i\bigoplus (n-i)∑i1n−1​i⨁(n−i)。 20%,n≤1e6;;50%,n≤1e9;;70%,n≤1e18;;100%,n≤1050020\%,n\le 1e6;;50\%,n\le 1e9;;70\%,n\le 1e18;;100\%,n\le 10^{500}20%,n≤1e6;;50%,n≤1e9;;7…

模板:常系数齐次线性递推(线性代数、多项式)

所谓常系数齐次线性递推&#xff0c;就是系数为常数的齐次线性递推。 &#xff08;逃&#xff09; 前言 sto Asta orz&#xff01; 又是一个名字高大上&#xff0c;实则小清新的算法&#xff01; 解析 考虑一个 k 次的线性递推&#xff1a; an∑i1kfian−ia_n\sum_{i1}^kf_…

2021牛客暑期多校训练营1

2021牛客暑期多校训练营1 题号题目知识点难度AAlice and Bob博弈论BBall Dropping计算几何签到CCut the TreeDDetermine the Photo Position签到EEscape along Water PipeFFind 3-friendly Integers真签到GGame of Swapping Numbers思维题&#xff0c;推导HHash FunctionFFT&a…

【无码专区12】子集和(背包dp)

此题已自我实现&#xff0c;但仍归于无码专区 本题在考场上就过了&#xff0c;所以难度并不高&#xff0c;发现性质即可。 problem 有 nnn 个正整数 a1,a2,...,ana_1,a_2,...,a_na1​,a2​,...,an​&#xff0c;他们的和为 mmm。你想对于其每一个子集 SSS&#xff0c;求出他…

Penguins

Penguins 题意&#xff1a; 有两个20*20的地图&#xff0c;有障碍物&#xff0c;两个地图各有一个小人&#xff0c;左侧地图的小人要从右下角走到右上角&#xff0c;右侧地图的小人要从左下角走到左上角&#xff0c;这两个小人是镜像移动的&#xff0c; 左侧小人右侧小人左移…

盲盒(随机概率 + 最大公约数)

盲盒problemsolutioncodeproblem 有 2n2n2n 个盲盒&#xff0c;每个盲盒有一个惊喜值 aia_iai​。 打开恰好 nnn 个盲盒&#xff0c;获得的惊喜值为这些盲盒惊喜值的最大公约数。 求能获得的最大惊喜值。 n≤1e5,ai≤1e12n\le 1e5,a_i\le 1e12n≤1e5,ai​≤1e12。 solution…

P5354 [Ynoi2017] 由乃的 OJ(树剖、位运算)

前言 当暴力思路与题解中的“暴力”不同时&#xff0c;继续想优化往往就渐行渐远了… 所以当没有头绪时&#xff0c;要勇于跳出原有的转化&#xff01; 这种位运算类型的优化似乎始终不在我的寄存器中…需要加强&#xff01; 解析 不难想到按位考虑的 O(nklog⁡2n)O(nk\log…

在 .NET Core 中运行 JavaScript

一.前言在 .NET Framework 时&#xff0c;我们可以通过V8.NET等组件来运行 JavaScript&#xff0c;不过目前我看了好几个开源组件包括V8.NET都还不支持 .NET Core &#xff0c;我们如何在 .NET Core 中运行 JavaScript 呢&#xff0c;答案是使用 NodeServices。关于为何有在 .N…

I love exam HDU - 6968

I love exam HDU - 6968 题意&#xff1a; 有n个考试科目&#xff0c;现在有m套复习资料&#xff0c;每套复习资料需要花费wi天使用&#xff0c;用完提升ci的分数&#xff0c;现在还有t天复习时间&#xff0c;挂科数目不能超过p&#xff0c;问所有达到的最大分数 题解&#…

[CF1442 D] Sum(分治优化dp + 结论)

CF1442D Sumproblemsolutioncodeproblem luogu翻译 solution 部分分做法&#xff0c;预处理每组前缀和&#xff0c;暴力背包 dpdpdp 转移&#xff1a;dpi,jmax⁡{dpi−1,j−ksumi(k)∣0≤k≤l[i]}dp_{i,j}\max\Big\{dp_{i-1,j-k}sum_i(k)\ \Big|\ 0\le k\le l[i]\Big\}dpi,j…

P4338 [ZJOI2018]历史(树剖)(暴力)

前言 有点懊恼的一个题… 并没有其他那些ZJOI那么毒瘤&#xff0c;看出了关键结论&#xff0c;但最后维护卡在log条虚边的伞兵性质上了。 解析 第一眼&#xff1a;感觉根本不可做啊。 冷静一下&#xff0c;既然它还变态的带修&#xff0c;一定是可以转化成比较形式化的东西的…

Named Volume 在 MySQL 数据持久化上的基本应用

原文作者&#xff1a;春哥非常感谢春哥的投稿&#xff0c;同时也有一些感慨。初识春哥时&#xff0c;春哥是美术设计大咖。后不久&#xff0c;创业并致力于游戏开发&#xff0c;已有3年。从Unity3D到IOS&#xff08;Swift&#xff09;开发&#xff0c;从前端开发到后端以及容器…