编程入门的第一课——建立编程思维

引子

写这篇文章的起因源于我和我老婆的一次讨论。上半年,她在学校里教Matlab。有一次我帮她解答一道上机的习题,大概用了50行代码左右。在解释完答案后,她就问我,“你一步一步是怎么想的?我好像就没有这种思维。”,这可把我问住了,因为那对我来说更接近于一种下意识的行动,很自然的就写出来了。这个回答她自然不满意了,那么这种思维到底是什么呢?

什么是程序

先让我们从什么是程序谈起。上大学时,估计大部分人都学过C语言,我清楚的记得谭浩强的那本书在开篇里提到,程序 = 数据结构 + 算法。从专业角度上来说,这个定义真是绝了,但相信对很多刚接触编程的人来说,会马上问什么是数据结构?算法又是什么呀? 所以在这里,我们先提出一个的通俗的解释。一个程序的作用就是接受输入,进行处理,然后产生输出,套用李笑来对写作的定义,程序也可以定义为:

程序 = 输入 + 处理 + 输出。

其中的处理代表着一系列有条理的操作,即流程化

发现事物的流程

什么是流程化?

以生活中的炒菜为例,食材是输入,最后的菜品就是输出。而下厨过程中的洗菜、切菜(预处理),然后下锅、翻炒、调味进行加工(处理),最后出锅、装盘(后处理)就是这个处理的全过程。

如果这个例子让你觉得离编程世界太远了,下面我们再来分析下笑来老师多次提到过一个例子。他在写第一本书《托福词汇21天突破》时,是运用编程统计出了高频单词。按照我的理解,这个程序的输入是历年来的试卷的电子版,然后按照按照空格进行分词,接着统计每个单词出现的次数,排除常用的简单词汇,再把同一单词的不同形式(比如,如果是动词就有第三人称,过去时,完成时等多种形式,如果是名词,至少有单复数两种区分,还有相应的动词,形容词)出现的次数加起来作为这个单词的出现的总次数,最后按照这个统计次数的高低排序,输出的结果就是高频词汇集合了。

流程化是建立编程思维的基础,发现事物的流程,是开始编码的第一步。但只知道根据流程来编码,写出的代码估计会像流水账式的文章,有很多冗余,要想写出优雅的代码,下面一步就需要识别出流程中变化和不变的部分,并对变化的部分进行封装,常见的方式是提取函数。

识别变化与不变的部分

你是不是在想,咦,流程中还分变化和不变的部分?这怎么理解。

下面让我们接着聊炒菜这件事,以流程中的洗菜、切菜这一步为例,洗和切这两个动作不变的,菜是变化,因为我们不管不做什么菜,都需要先洗再切,但是每次的菜是可以不同呀,于是我们就可以封装菜这个变化的点,从而提取出两个函数:

函数名:洗

输入:菜

输出: 洗好的菜


函数名:切

输入:洗好的菜

输出:切好的菜

(如果你在想为什么不是一个函数?原因是单一职责原则啦,这个我们后面的文章中再讲)


顺着这个思路,我们再来看加调料这一步,炒一个菜,通常需要加不同的调料,比如说糖,醋,盐。每种调料需要加的多少也是不一样的,比如说20克,10克和5克。于是加调料这一步也可以封装成一个函数:

函数名:加调料

输入:1.调料名 2.重量

输出:添加指定重量的指定调料


再来笑来老师的计算高频词汇的程序,它有哪些变化的部分呢?请想想再看下文。这里我想到的一个点是统计单词出现次数的部分,统计的方法是一样的,不一样的是统计的单词,于是可以得到以下这样一个函数:

函数名:统计单词出现次数

输入:某个单词

输出:这个单词到目前为止出现的次数


当你能够准确识别出流程中变化和不变的部分时,你就可以得心应手的的写出百行左右的小程序。如果你要再进一步写出一个软件,那么需要的就是抽象能力了。

确定抽象与具体的界限

抽象这个词本身就很抽象,编程中到底需要抽象些什么呢?我的理解是抽象是指抽象实体或者职责。遗憾的是这个可能已经不属于入门的阶段要了解的知识了,我后续准备再补写章讨论这些地方。在这里,我只想提一点,在你开始运用抽象能力的时候,一定要注意确定抽象和具体之间的界限是否合适。

比如说,一个抽象的流程可以这样描述,一个任务可以通过预处理、处理和后处理三步完成。你会发现无论做香辣虾,统计词频都可以用这三步完成。做香辣虾时清洗大虾是预处理,下锅翻炒,调味是处理,摆盘算是后处理了。统计词频中按空格分词是预处理,统计每个单词出现的次数是处理,按出现次数大小排序就算后处理了。这样的抽象就属于抽象程序比较高的,它的优点是可以适配的诸多场景;缺点也很明显,太过抽象以至于只看这三步时,根本不知道要做什么。

而我们在前面指出的炒菜的流程,先是洗菜、切菜(预处理),然后下锅、翻炒、调味进行加工(处理),最后出锅、装盘(后处理)。相比来说就是更加具体的抽象了,因为它没有说明要做什么菜,但是做任何一道菜都需要这些步骤。

上述两种抽象的方法到底哪个好,则要结合具体的场景来分析。如果只是炒菜,那么第二个更好;如果是为处理任务提供一个通用的方法,第一个则要胜出了。所以在实际编程中,合理的确定抽象和具体之间的界限就是编程思维中最重要的一环。

总结

如果我们把程序定义为, 程序 = 输入 + 处理 +输出。那么编程思维,就是先发现事物的流程,然后识别变化与不变的部分,最后确定抽象和具体之间的界限。

自己是一名程序员,写关于编程方面的文章算是自己的本行了。这里先做下预告,本文是自己准备写的编程系列第一篇文章,陆续还将写编程新手进阶,编程高手展望等方面的文章,欢迎继续关注。

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

推荐阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,567评论 18 399
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,594评论 18 139
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,428评论 25 707
  • 他说:“帮我个忙吧!” “嗯?有什么事,你尽管提,只要能做到,竭尽全力” 他慢慢的张开了嘴,“你帮我去杀一个人。”...
    Nanccccc阅读 258评论 0 1
  • 生活是孩子最好的老师!
    含笑花阅读 179评论 0 3