编程的时候我都在干什么

【核心观点】

  1. 编程应当带有明确的目的,就是解决一个问题或满足一个需求
  2. 如果要让计算机程序解决问题,那就先了解没有计算机程序的时候是怎么解决问题的
  3. 如果遇到了技术问题,先想想自己最终要实现什么,然后再考虑如何解决眼前的问题
  4. 编程不是有勇无谋的冲锋,神挡杀神,佛挡杀佛不可取;换个思路,眼前的问题可能就不是问题了
  5. 和非技术人员的沟通应当屏蔽技术细节
  6. 程序员不了解业务会严重影响其生产力

【故事】

在部队的很长一段时间内我的主要工作内容被规定为如下几个方面:

  1. 确保通信机房的网络设备和网络安全。
  2. 维护若干个新闻网站服务器和上面的代码。
  3. 根据领导的工作意图配合相关业务部门编写相关软件以完成工作任务。
  4. 物色人员组建和领导编程团队。

在一段时间内,我拥有一个比较稳定的研发团队并带领他们对日常的业务工作提供一些信息化支持。我的几位领导非常重视我们的工作也很认可我们的工作成果,因此我们这个团队在一段时间内产出了很多实用的软硬件工作。

当我带领着我们的小团队在进行编码的时候,我们的电脑屏幕上充斥着花花绿绿的代码,我敢保证问我们在写什么的人没有100个也至少有99个。我会不厌其烦的回答他们。

一开始我试图解释清楚我正在编写的代码是如何工作的(是的,我在向对编程技术一无所知的人解释一段代码)。

“嗨!027!你们在干什么?”

“这位同志你好!我们在写代码,你现在看到的就是数据库查询语言,首先我得从数据表里面对数据按周统计数量,我们用的mysql数据库,它有几个内置函数就支持我们这样去干,所以我需要写这样一个SQL语句,先在数据库里面进行测试,确定没问题的时候,我把他插入到程序逻辑里面去,用一种比较安全的方式进行参数注入。我有一种巧妙的方式去规避SQL注入的风险,你知道吗SQL注入是一种很危险的漏洞,它会导致 ……”

“额… 027同志,你们辛苦了! 我还有别的事情,我就先走了,你们忙啊!”

很长一段时间,我都是这样在向别人介绍我们的工作,大家总是对我们敬而远之。很明显,我的眼里只有我眼前正在干的事情,我的目的就是炫耀自己的技术。但事实上,别人并不会关心你使用了什么样的技术路线,也许问我问题的同志就真的只是单纯的想知道,我写的这些代码是解决什么问题的。

对呀!当我在编程的时候,我是在解决现实问题!也许一开始,我还很清楚我要解决什么问题,我有一个大概的规划,先干什么,后干什么。可随着工作的深入,我会逐渐忘记最初的目的,陷入技术细节无法自拔。尤其是当我遇到某一个无法解决的变成细节问题的时候,我会想方设法的去互联网上搜索错误代码和错误提示,向搜索引擎的输入框描述自己所遇到的问题,花费大量的时间去尝试和验证别人的解决办法 ,最终我总是会解决当下的问题,但往往也会因为用了别人的代码或者思路而引出来新的问题。刚入行的那会儿我总是处于上面描述的状态中。一个比较典型的例子就是在我开发新闻网站稿件采集和上报程序的时候所走的弯路。

当时我们刚刚完成自己单位新闻网站的重新设计,在内部我们有一套完整的解决方案,我们使用了基于Python语言的Diango框架进行新闻网站的开发,编写了很多HTML模板,这样我们只需要重写Django默认的TextAre组件,将其改造成为一个富文本编辑器即可完成新闻稿件的在线编辑和发布。这个富文本编辑器产出的HTML代码会被我们存储在数据库中,然后在我们的网站中把这段HTML插入到文章详情页中。这样我们的新闻页面就有了固定的Header和Footer模板,这套技术也是新闻网站新闻详情页的一般解决方案,他在我们单位的新闻网站上运行一切正常。

在新闻上报的时候,我们需要将需要上报的新闻的HTML代码打包成zip文件,然后人工登录上级网站给定的新闻上报界面并上传给上级。为了简化这个工作,我研究了上级网站的接口协议,通过爬虫的方式进行了自动zip压缩和上报。随之而来的问题是,当我们把稿件上报给上级单位的时候,上级单位的新闻详情页不会显示网站的header和footer信息,而且总是或因为缺失css样式出现排版错乱的情况。为了解决这个问题,我开始重构新闻上报模块,并煞有介事列出了如下TODO清单:

解决上报新闻没有header和footer并且缺失css的问题的待办清单:

  1. 查看上级网站,用chrome开发者工具进行调试,找到缺失的css代码。
  2. 重写新闻导出模块:把我方网站的文章详情模板和文章内容进行拼接,产出新的index.html文件一同打包的zip包内再上报。

很快,我解决了css缺失和网站没有header与footer的问题,可是紧接着又发现上报的网页图片挂掉了,原来在打包的时候没有将图片一同打包,然后我又开始了进一步调整。最终,这些问题都得到了解决,差不多用了整整两天时间。我很确信,我当时很努力地在解决问题,而且我解决问题的办法也很有效,发现问题,解决问题,我的编程工作也很有成效。只是在问题排查的时候确实很让人头疼。但随后我就发现,我错了……

经过我修改的程序的确能够很好的工作,但是我不该花那么多时间去解决这个问题。在遇到问题的时候,我忘记了要解决的问题的本质,把精力放在了眼前的css缺失和模板缺失的问题上,并且很快就下决定去解决两个问题,由此还引出了很多新的技术问题(后台渲染和页面静态化)。可是,上报新闻的本质就是把我们网站上的一个页面存储成html文件并压缩成zip包然后上报就好,那么我为什么不用一种更简单的方式呢?比如下面这种办法:

实现新闻上报的编程步骤:

  1. 在本地网站发布新闻
  2. 使用curl仿问本地网站的新闻页面
  3. 保存curl的返回结果并压缩成zip包
  4. 自动上传zip包到上级网站

是呀,我只是要上报本级网站的某一个页面到上级就好,为什么要调整我本级网站的代码呢?只需要把这个页面下载下来打包上传即可啊!

由此可见清楚编程的时候自己在干什么?这是编程的第一要务!他可以避免你在没有摸清问题本质的时候盲目的干下去,从而浪费大量时间和精力。经过这次事之后,我在编程的时候,就总会问一问自己到底要干什么?要实现什么目标?解决什么问题?尽量确保自己不要因为陷入某一个技术细节而忘记最初的目的。

在此之后,再有人来到我的办公室问我在写什么的时候,我就能很明确的告诉他们我在干什么。也许编程本身就是一个很朴素的概念,那就是让计算机自动替我们完成一些事情。

“嗨! 027同志! 你在写些什么?”

“嗯!你好同志! 我在编写一个程序的功能模块!假设你是一个新闻编辑,你应该很想知道自己这个星期到底发了多少稿子,并且也很想了解到其他编辑的发稿数量吧,我想有了这个功能,你就可以避免自己总是落后别人了!我就是为了帮你解决这个问题!”

“好吧!确实很有用!但是这卷的也太厉害了!再见!”

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

推荐阅读更多精彩内容