好程序员不用windows作为开发环境,今天我想就这个点吐槽一下。最近因为工作关系,需要在windows机器上工作一段时间,作为一个用了多年windows,然后切换到ubuntu作为工作环境两年时间,然后切换到mac大概3年多时间只到最近被迫用回windows的程序员,我大概有自己的一些感触。当然,如果你碰巧用了微软的技术栈,或者在开发windows平台应用或者是windows phone应用,很遗憾,你没什么太多选择。如今我写的程序主要是web居多,移动的以iOS为主,辅以一些小工具或者库,了解我的这个背景后,大概会觉得我不那么偏激一些。
好程序员首先追求效率,这一点体现在方方面面。他们不会过度依赖于IDE,而会大量使用命令行工具。他们希望一切都尽可能地快,不光程序运行要快,开发过程也要流畅、没有阻碍和干扰,无聊重复的工作希望能够通过工具自动完成。
举个我每天都要用的terminal来说,如果你在mac或者linux上学习掌握了bash以及一些核心的GNU linux工具箱的用法,那么在所有linux平台和mac平台上都可以很高效,并且切换无成本。现在的shell多数都用了readline这个库,也就是说它们支持类似的一套快捷键,例如Ctrl+a
回到一行开头,Ctrl+e
到一行结尾,Ctrl+r
可以匹配查找历史命令,等等。而直到Windows 8,系统自带的terminal工具cmd还和windows 95里的cmd没什么区别,好像微软从来没期望windows上的程序员去使用命令行工具(你们用visual studio就够了)。不要说快捷键,连进行最基本的copy paste都是一个非常痛苦的事情,更不要提在中文windows下你只能选择一种系统默认字体,窗口的大小不能简单拖拽进行调整…… 我确实看到很多windows上开发的程序员都不怎么用命令行工具,他们默认遵循了windows的设计哲学,那就是一切都通过GUI(图形界面)来完成。
前面提到linux下的GNU工具箱,如果你用过grep、find等工具应该不会陌生,现在除了这些传统工具,还有ack、autojump等新的工具,对于程序员来说十分顺手。在mac下,通过brew或者port,也可以很容易通过命令行工具从远程软件库安装这些工具。而在windows下面,准备好这样一套环境必须得费一番功夫。当然你可以选择cygwin,或者一些较小的linux工具移植(例如mingw utils, GnuWin32等),现在也有nuget和chocolatey这样的软件安装和版本管理工具(类似linux下的apt-get或者mac下的brew),但是仍不是非常理想,不同工具的安装体验也非常不同,而它们对linux的模仿也刚好印证了linux类系统的先进。
最近我也发现了好几个windows上cmd工具的替代,例如powershell,有它自己的优势,还有类似powercmd,powertab,console2等工具,也是希望能够给windows带来更多类似linux和mac上terminal类工具的功能。
除了terminal本身,shell script也比win上的batch script强太多了,powershell的出现让windows也具备了较强的脚本能力,然而shell脚本的强大和广泛应用还是powershell不能比的。在linux上,init和系统配置大多是shell脚本,不论是用bash、ruby还是python写出来的脚本,使用起来和用C语言写成的sed、awk等工具没有什么区别,作为用户,这些脚本的使用体验就和原生工具一样,我们熟悉的vagrant、chef、hg等工具都是脚本写的。而windows上,bat脚本的能力有限不说,其执行体验也差了很多。
不仅是工具,在执行效率上linux也比windows强很多。
我们现在开发很多web应用,很少有部署在windows平台上的,如果你是采用pythong、ruby或者java等语言来开发web,多数情况下你会部署到linux平台上。为什么,因为linux平台执行效率高,而且作为老牌服务器平台,有很多免费的优秀开源服务器软件。这样,我们很多程序员往往在windows上写java代码,在linux上部署war包。
可能有人会问,linux作为服务器效率固然不错,作为开发环境也许差点。我目睹过一个团队从windows切换到linux开发环境后,构建脚本的执行时间从十几分钟缩短到了7分钟左右。linux的文件系统比windows要快,很多脚本解析器的实现也更高效,因此解释执行的效率也更高。
除了效率,我也关注体验。
在mac上,所有程序的界面风格都是一样的,任何一个工具和应用,你都可以用同样的快捷键来进行基本操作,而在windows上,大多数的程序交互风格都不一样;linux和mac上所有命令行工具都是差不多的参数语法,而windows上的命令各有各的参数风格;linux和mac上所有命令行工具都有man文档,而windows上大部分工具都没有合适的文档;在大多数linux平台上,ruby、python、java已经默认安装了,而在windows上,光安装ruby+rails就有一个专门的团队来为其制作安装包了。
在linux和mac上,我在命令行里基本上可以完成所有任务;在windows上,如果我要ssh服务器,我要打开putty,如果我要启动mysql,我得找到mysql工具的快捷方式,启停服务我要到service管理窗口,加个环境变量我得鼠标左右键点击n多次到一个尺寸不能调整的小窗口里手动添加,完了我还得不得不重启cmd窗口。
在linux和mac上,现在很容易可以写一个脚本,把一个开发环境所需要的所有内容都自动化安装执行好,我们不需要一个文档来记载每一个新来的程序员所需要做的安装准备工作。在windows上,我也用powershell写过类似的东西,开发和维护这套脚本的体验都不太好。
我承认习惯是一个很强大的力量,毕竟当初我从win xp切换到ubuntu的时候,也是花了好一阵才能适应。现在之所以我这么抱怨windows,也可能是我在mac下活的久了的缘故。加之现在的IDE例如intellij和Visual Studio已经把java和.Net开发支持的很不错了。但是如果你的工作不只是在开发机上写写代码,你应该能够体会我前面说的那些差异。且不说windows平台作为web应用的部署平台早已没有任何竞争力,在我看来,作为开发环境,也已没有任何吸引力。