程序员

关于开发环境的笔记

2018-04-20  本文已影响56人  开水的杯子

前一阵子去了一个都是新手的开源写码活动,颇有些感慨。其一是发现新手加入一个开源项目的难处其实完全不是写代码。其二是发现有了一点工作经验之后,很容易把很多东西视为常识而忘记从零学起的时候是什么感觉,一个不小心不耐烦可能会让别人很难受。何曾几时我也是带着星星眼跑去实习的菜鸟,满心崇拜又十分自卑地望着那些看起来很厉害的同事,羡慕他们各种炫酷的IDE和shortcut,别人无意的一句“怎么你连这个都不会”还是蛮囧的。

其实在写代码之前有好多事情要做。比如说你要先:

  1. 把代码库克隆到你可以读写的环境里
  2. 装好代码库需要跑的依赖包(dependency为什么翻译成这个我也不知道)
  3. 搞明白如何运行你的代码
  4. 搞明白如何测试你要达成的feature或者是要修的bug
  5. 找到你要改的代码在哪里
  6. 搞清楚你们代码库的版本控制怎么用

然后在写代码之后,也有很多后续工作:

  1. 手动测试。我修了这个bug到底修好了没?
  2. 回归测试(regression testing),我加了代码有没有搞坏别人的feature或者搞出新的bug?
  3. 写测试。如果是修了bug,那就要写regression test。如果加了feature,那应该写unit test或是integration test来确保以后如果有人在未来写了点什么搞坏了我的feature或者bug,可以在自动测试阶段就知道。
  4. 提交code review,回复code review,改代码,merge upstream的代码(rebase/merge/resolve conflicts)。
  5. 最后提交到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观察一下,你会发现包括logincd,和python的很多常用指令和程序都在这里。你之所以能够不需要absolute path去找cdpython,是因为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本身:

好像我好久以前也写过一个bash入门:https://www.jianshu.com/p/1343e83e0d92

上一篇 下一篇

猜你喜欢

热点阅读