前一阵子去了一个都是新手的开源写码活动,颇有些感慨。其一是发现新手加入一个开源项目的难处其实完全不是写代码。其二是发现有了一点工作经验之后,很容易把很多东西视为常识而忘记从零学起的时候是什么感觉,一个不小心不耐烦可能会让别人很难受。何曾几时我也是带着星星眼跑去实习的菜鸟,满心崇拜又十分自卑地望着那些看起来很厉害的同事,羡慕他们各种炫酷的IDE和shortcut,别人无意的一句“怎么你连这个都不会”还是蛮囧的。
其实在写代码之前有好多事情要做。比如说你要先:
- 把代码库克隆到你可以读写的环境里
- 装好代码库需要跑的依赖包(dependency为什么翻译成这个我也不知道)
- 搞明白如何运行你的代码
- 搞明白如何测试你要达成的feature或者是要修的bug
- 找到你要改的代码在哪里
- 搞清楚你们代码库的版本控制怎么用
然后在写代码之后,也有很多后续工作:
- 手动测试。我修了这个bug到底修好了没?
- 回归测试(regression testing),我加了代码有没有搞坏别人的feature或者搞出新的bug?
- 写测试。如果是修了bug,那就要写regression test。如果加了feature,那应该写unit test或是integration test来确保以后如果有人在未来写了点什么搞坏了我的feature或者bug,可以在自动测试阶段就知道。
- 提交code review,回复code review,改代码,merge upstream的代码(rebase/merge/resolve conflicts)。
- 最后提交到master,deploy到production。
回到某一年在CS106B之后CS 142之前的某个寒假,心血来潮想装mysql写个app。装了整整一个寒假啊……
关于开发环境和依赖保
(本文适合Linux用户。抱歉啊Windows用户。)
Terminal中的程序是如何运行的
在类似CS 107的入门系统课里大家会学到,自己编译好了的executable,比如说叫foo的,我们可以用指令./foo
来运行它。或者用它的absolute path~/my/path/to/foo
来运行它。当然前提是foo这个文件有运行权限。我如果从网络上当下来一个程序,比如说这个常用的get-pip.py,我也可以用./getpip.py
来运行它(当然前提是我装了python)。但从网上当下来的binary一般没有运行权限,所以我们要用chmod +x ./get-pip.py
来先给它运行权限。
那为什么有的程序,比如说python,不需要我们用absolute path去跑呢?
PATH变量
你的Linux电脑上大多数自带的程序在/usr/bin
这个文件夹里。如果你用ls /usr/bin
观察一下,你会发现包括login
,cd
,和python
的很多常用指令和程序都在这里。你之所以能够不需要absolute path去找cd
和python
,是因为Linux有一个叫做PATH
的变量。
你可以用echo $PATH
这个指令来探查一下:
echo $PATH
/usr/local/git/current/bin:/usr/local/bin:/usr/bin:/bin:/usr/local/sbin:/usr/sbin:/sbin
PATH变量指定了一堆的文件夹,它的作用就是我每运行一个指令(比如foo),它会先按顺序在PATH里指定的文件夹中先找一下,看看这个文件夹中有没有foo这个可以运行的程序。
打个比方,这个博客里阐述了一个常见问题:就是苹果电脑装git必须先装xcode。
这个是因为苹果电脑自带一个依赖于xcode的git(其实就是想强迫你装xcode而已),而由于PATH变量的顺序问题,你运行git的时候会先找到苹果版的git而不是你自己新装的git。那解决方案也很简单。就是给PATH变量加一个前缀,让它先找到你自己装的git而不是苹果自带的git就可以了。
echo "PATH=/usr/local/git/bin:\$PATH" >> ~/.bash_profile
.bash_profile
和.bashrc
是什么鬼
你的root文件夹里(也就是~)有两个神奇的dotfile,.bash_profile .bashrc。你每次打开一个新的terminal,.bashrc里面的所有指令会自动跑一遍。在macOS上,这两个文件的效果是差不多的。
这个文件适合加你所有对PATH变量的前缀,适合用alias指令偷偷懒,适合设置环境变量,也特别适合恶作剧(关于如何恶搞男朋友的电脑大约可以再写一片文章)。
以前上系统课的时候常用C,于是bashrc里面写了:
alias m='make clean && make'
alias mc='make clean'
后来多写前端,就有了:
alias myserver='python -m SimpleHTTPServer 8000'
alias server='python -m SimpleHTTPServer 8000'
忘记自己都谢了哪些alias?没问题,terminal里面打一下alias
,你曾设过的所有简令就出来了。
Homebrew一键简化人生
过了基础课之后,你会发现不管写什么程序,都要装一堆的依赖包。写后端用到数据库,就要装个sql,mongo啥的。写前端更要装什么npm, node, yarn, gulp之类的一堆。都是一些常用程序,每一个有自己奇葩的安装方式。Homebrew是一个package manager。有了它你基本不用专门去看每一个package自己的独特安装方式,
brew update && brew install name-of-my-package
就完事了。Homebrew具体是干嘛的呢?其实绝大多数的package安装说白了就是把可运行的部分丢进/usr/local/bin里面。Homebrew并不直接管理你的/usr/local/bin。它会自己建立一个叫做/usr/local/Cellar的文件夹,在Cellar里面把程序装好,然后symlink到/usr/local/bin里面去。
npm和yarn就暂且不讲了。这里有几个比较好玩的练习可以熟悉一下terminal本身:
- 给terminal装个漂亮的皮,比如说solarized。
- bash-it, oh-my-zsh, 或者装个git prompt
- 装个nerd tree修饰一下自己的vim。这个比较针对vim真爱粉。
好像我好久以前也写过一个bash入门:https://www.jianshu.com/p/1343e83e0d92