對於程序員來說,其實Tab和空格遠遠不只是“立場”問題那么簡單。
在不同的編輯器里tab的長度可能不一致,所以在一個編輯器里用tab設置縮進后,在其它編輯器里看可能縮進就亂了。空格不會出現這個問題,因為空格就占一個字符的位置。
眾所周知,Tab在ASCII碼中,編碼是9,而空格是32。這也就是說,當我們按下一個Tab的時候,即使它看起來就是8個空格(或者4個空格,不同的環境下,Tab可能顯示的效果不同),對於電腦來說,卻是完全不一樣的東西。這也意味着,對於用字符來描述過程的代碼來說,極有可能會是決定性的差異。
尤其是對於一門用空格縮進來區分代碼層次的語言——Python。
我們來看一段代碼。
class MyForm(Form): value1 = StringField('value1') value2 = StringField('value2') value3 = StringField('value3') #這行用的是Tab縮進 submit = SubmitField('Submit')
看起來這個value3變量和其他的變量沒有什么不同,然而卻出現了這樣的報錯——縮進錯誤。
value3 = StringField('value3')
^
IndentationError: unexpected indent
其實Python並沒有強制要求你用Tab縮進或者用空格縮進,甚至空格按幾個都沒有強制要求(但在PEP8中建議了使用4個空格作為縮進:https://www.python.org/dev/peps/pep-0008/),但是卻絕對!絕對不能混用Tab和空格,那么這里,是不是空格和Tab的區別就顯得很大了呢?
這個時候有的童鞋就要說了,我用PyCharm(或者其他IDE)怎么從來都沒有出現這樣的問題呢?
其實,很多IDE對Tab鍵做了各種各樣的優化,其中有一條就是,將Tab鍵展開為為空格,也就是說,當你按下Tab的時候,IDE實際上幫你把一個「9」轉換成了四個(或者八個)「32」。但是要注意,不是所有的IDE都幫你做了這樣的工作!同理,對於好純潔好不做作的編輯器Vim來說,肯定也不會幫你做這樣的工作了。
既然Tab在不同的環境下展現不一樣,而空格卻永遠都是一樣的。對於一些細致排版縮進來說(比如說想把每一行的注釋都對齊),用空格也更加精確。這樣看起來,確實是用空格來寫代碼要好於用Tab呢。
空格代替Tab的好處:
1. 空格在各種情況下代碼都是你想要的樣子。而 tab 僅僅當你與代碼作者的 tab 尺寸設定為相同時,代碼才好看。修改 tab 尺寸並不能解決這個問題,因為你很難做到每打開一個文件就修改一次 tab 尺寸,而每個人通常有不同的習慣(POSIX/Unix 標准的 tab 應當為 8 字符寬度,Linus 大神也規定 Linux 內核中所有代碼的 tab 尺寸為 8)。如果存在行尾注釋,則 tab 尺寸更加是必須設定為與作者相同,這就意味着你看不同的代碼需要經常修改 tab 尺寸。我看過許多代碼,其使用的 tab 尺寸有從 2,3,4,5,6,8,16 甚至 32 的,如果你使用的 tab 尺寸與作者不同,外觀將很不理想。
2. 靠譜的IDE都能解決前進后退增加減少縮進的問題,即便是四個空格,一個退格鍵也能全退了,所以在使用的方便性方面根本不存在問題。——如果抱怨刪除調整還不能有效解決的,你需要研究一下你的編輯器了。實際上增加減少縮進在主流編輯器中都直接有快捷鍵,無論是 tab 還是空格還是退格都很少直接被用於縮進。
3. tab 是制表符而不是縮進符,正如在 html 頁面中大量使用<table>進行布局是個不好的編程習慣一樣,在編程中大量使用制表符布局通常也不是個好習慣。
一般情況下,團隊開發都要制定一套編碼規范, 在大部分團隊中,使用4個空格代替Tab是大家默認的。所以非常建議大家使用空格代替Tab, 另外各個IDE(編輯器)都提供了tab自動轉換空格的功能,只要大家設置一下,按下tab鍵就可以出現4個或者多個空格。