搞软件的配叫工程师?

软件行业存在很多类比,常常类比开发系统就是建造大楼,那么软件开发者就相当于建筑工程师啊,但是工程师群体常常嘲笑软件开发工程师,你们的专业训练哪有我们严格?时不时服务就有问题了(尽管不得不承认牛逼网站能够做到好几个9的可用率)。对建筑工程师来说这都是重大事故啊,基本是零容忍的,你们软件设计也能称之为设计?我们一栋楼那是承担人们生命安全的东西,在地震区得考虑防震,在飓风区至少得经过很多轮测试,你们写几段代码,就能叫工程师了?

诚然,建筑行业和软件行业不能完全拿来对比,我外公以前是从事建筑行业的,修建一个公园的亭子,都需要仔细画若干张图纸,等一切资源到齐才能撸起袖子干。软件开发,启动成本多低,一段脚手架生成代码敲几个字母,所谓“原型”就出来了,前前后后可能还没有一个小时。其次,建筑行业的设计者和实施者,那是分的相当开,我们哪见过建筑设计师拿着铲子和水泥,一片片垒砖的。并且,软件行业提出了很多独特的开发模式: “极限编程”,这在建筑工程师那里简直不可想象,毕竟建造这件事情不是轻易能够迭代的。软件开发者很可能就说:不就几个功能嘛,时间这么紧,两下搞定,要毛设计~~

然而,最近深度介入一个生命期已经接近两年的代码项目,深刻意识到 拿捏“设计” 的意义。很多所谓码农,可能跳槽频率较高,刚生出来一个项目,还没来得及看看这个项目怎么在复杂的商业环境下演变就离职了,没有机会尝试演进化的设计。

不得不承认,项目初期每个人都很难拿捏需求,工程师可能会想我这种设计模式绝对能满足你们未来100个需求点,但是,商人头脑里的东西那是捉摸不定啊(此时cue下特朗普),他能给你搞1000个需求,所以前期设计那肯定是得摸着石头过河。有些时候,我们常常容易“过度”设计:“很可能未来还会有这种需求,那我就搞个“类”,把所有共享变量放在一起,机智如我!”,然而,未来压根就没有这种需求,大部分时间我们YY的都是错的。因此,“奥卡姆”剃刀中讲的,大道至简,用最简单并且能够让人一目了然知道你在干什么。

难道这样说,我们就放弃“设计”,来一个需求就干一个需求。经典的软件设计课程会告诉我们,能在前期解决的一个问题留在项目后期,那成本翻了可能有100倍,我们说演进化设计,是要这个系统生长,但是要健康生长,如果一个代码库生长出各种错综复杂的逻辑,而且引入如此多“黑魔法”,那维护成本相当高。这就相当于生长成一个“怪物”,想要驯服,太难了。

Martin Fowler 《重构》这本书其实给出了一条明路,保证测试足够的情况下,我们可以驯服这个怪物,修剪掉重复代码,保持“简单”的设计哲学,这种定期的代码审查,逻辑重构,保证软件在演化过程中按照规矩成长。经典的设计模式就可以在这时候发挥作用,毕竟是前人在种种尝试中摸索出来的pattern,前期如果为了设计模式而设计模式,很可能就过度设计了。但是在重构基础上,再引入设计模式,那就是控制了代码复杂度。

演进式设计也不完全是“摸着石头过河”,毕竟很多人都走过这样的路,如果不是一个特别有技术壁垒的项目,其实都可以通过网上找到相应的经验。要做一个实时聊天系统,那么多大公司分享出来的原型,先跑一两个,快速学习其中可能遇到的挑战,再进行相应的规划部署,这就是一种有效设计。

所以对于“搞软件的配叫工程师?”,我希望是。最后开一个脑洞:目睹一个项目两年的演进可能对于任何一个人来说都比较难,毕竟我们的生命很有限,所以很多情况下我们只会考虑近期利益。倘若我们要一段程序自己玩,时不时更改一些变量,用大量测试作为外部环境,我想有可能自动就进化和演变出一段“好”程序。不过,很可能我们人类估计都看不懂这段代码了。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,835评论 4 364
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,598评论 1 295
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 109,569评论 0 244
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,159评论 0 213
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,533评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,710评论 1 222
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,923评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,674评论 0 203
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,421评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,622评论 2 245
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,115评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,428评论 2 254
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,114评论 3 238
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,097评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,875评论 0 197
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,753评论 2 276
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,649评论 2 271

推荐阅读更多精彩内容