从小开始学编程的小姐姐自述:我变成更好程序员的三点心得体会

Keri Savoca 发在 Medium
量子位 报道 | 公众号 QbitAI

编者按:最近,国外一名小姐姐分享了自己的编程学习经验,引起了不少关注。她名为Keri Savoca,小时候就学了HTML并开发了网站。之后又学习了SQL语言以及JavaScript和Ruby等。在这个过程中,她也积累了不少感悟与经验,并分享了出来。有人阅读了之后称,文章里面的确有比较扎实的干货。希望能够给你带来启发。

从小开始学编程的小姐姐自述:我变成更好程序员的三点心得体会

编程并不是要你告诉计算机做某事

很多人都以为,编程就是要告诉计算机去做某事,就只需要编写一个命令,就像 do X一样,问题就解决了。

这其实是一个很大的误解,编程需要的不是do X,而是:

  • Do X to Y
  • Get X from Y
  • Get X from Y, and put it in Z
  • Create X in Y
  • Create X in Y, and make it do Z

等等。

只有开始写代码来解决实际问题,才能意识到这一点。

比如说,从BigQuery 中提取一组数据,并将其连接到Data Studio中做条形图。

一般情况下,可以通过点击按钮对X轴上的参数进行升序或降序排序,但你想要根据BigQuery中的维度进行自定义排序的手,就需要代码来解决这个问题了。

假设想要完成的X轴上的排序顺序是:A, D, E, B, C, F,排序顺序与其在“table001”中“location”维度有关系,可以这样解决:

ELECT *,
CASE
WHEN location = ‘A’ then 1
WHEN location = ‘D’ then 2
WHEN location = ‘E’ then 3
WHEN location = ‘B’ then 4
WHEN location = ‘C’ then 5
WHEN location = ‘F’ then 6
ELSE 0
END as SortOrder
FROM
table001

现在可以根据 SortOrder 进行排序,这是自定义的,而不是升序或降序。

这就是所谓的do X,但编程远远没有结束。因为这些只存在于控制台中,而没有实际应用。

编程到这个阶段,才刚刚完成了一半。

这听起来像是一个常识,但对于刚开始编程的人来说,可能需要过一段时间才能够在概念上有所理解与体会。

写代码是为了解决问题,不要太依赖教程

但根据说明性教程学习编程的时候,却很难学到这一点。

因为你不是在真正解决一个问题,而是在遵循一系列的指令。

当你正确的遵循这些指令的时候,就会产生一个特定的结果。

但如果你要去解决一个尚未解决的问题时呢?就没有任何指令可以遵循了。

在学习编程的时候要注意到,学习到的技能应该是可以转换的。如果你不能把你练习的技能应用到不同的场景中,跟着教程学习就没有意义。

基于这方面考虑,上面的示例应该要加上because这个词:

  • Do X to Y because …
  • Get X from Y because …
  • Get X from Y, and put it in Z because …
  • Create X in Y because …
  • Create X in Y, and make it do Z because …

当你学会了制作一个待办事项列表应用程序的时候,你应该学到的是,如何使用相同的概念来使应用程序以类似的方式运行。

多试试伪代码,可以提升算法思维

当写出来的代码没法运行的时候,你要怎么做?

很多人的方式是试错,尝试不同的方法来解决问题。

结果无非两种:要么终于起作用了,要么不起作用。

这并不是在于对编程语言缺乏理解,而是算法思维上的问题。

比如你想写一段代码,从Y那里得到X,然后放到Z里面。

却发现不知道从哪里得到了Z,然后试着把它放到了X中。

该怎么办?只是试错可能解决问题,但很难知道到底哪里错了。

一种英国学校学生经常玩的游戏“FizzBuzz问题”通常被用来当做编程面试中的题目,也可以作为练习“伪代码”的测试:

写一个程序打印1到100这些数字。但是遇到数字为3的倍数的时候,打印“Fizz”替代数字,5的倍数用“Buzz”代替,既是3的倍数又是5的倍数打印“FizzBuzz”。

从小开始学编程的小姐姐自述:我变成更好程序员的三点心得体会

技术博主闻波(webary)在过去的一篇博文中说,就这样的一个小问题,很多优秀程序员顺手就能写出来方式,但很多计算机专业的毕业生都不会做或者花费更多的时间去做。

背后的原因,就是忽略了如何想出解决问题的办法,而是一上来就想代码实现的问题。

而伪代码是一个比较好的方式,会引导你从算法开始思考。

这不需要你去考虑用什么语言来解决问题,而是先想出解决问题的办法。

原文链接:
https://medium.com/better-programming/the-3-realizations-that-made-me-a-better-programmer-af7d1bcab4d3

简单却又复杂的FizzBuzz面试编程问题
https://www.cnblogs.com/webary/p/6507413.html

版权所有,未经授权不得以任何形式转载及使用,违者必究。