為什么 Python 沒有 main 函數(shù)?
點擊關(guān)注上方“SQL數(shù)據(jù)庫開發(fā)”,
設(shè)為“置頂或星標”,第一時間送達干貨
眾所周知,Python中沒有所謂的main函數(shù),但是網(wǎng)上經(jīng)常有文章提到“ Python的main函數(shù)”和“建議編寫main函數(shù)”。
其實,可能他們是想模仿真正的main函數(shù),但是許多人都被誤導(或誤解),然后編寫了非常笨拙的代碼。
在本文中,我們來討論一下為什么Python沒有main函數(shù)。
在開始討論之前,我們先來回答以下兩個問題:
所謂的“main函數(shù)”究竟是什么意思?
為什么有些編程語言必須編寫main函數(shù)?
一些編程語言將main函數(shù)作為程序的執(zhí)行入口,比如C/C++、C#、Java、Go、Rust等等,這個函數(shù)具有特定的含義:
main函數(shù)名是必須的,這意味著必須有一個主函數(shù)。
最多只能有一個main函數(shù),這意味著程序的入口是唯一的。
語法格式有特定要求,書寫形式也相對固定。
為什么必須強制main函數(shù)作為入口?
這些語言都是編譯語言,需要將代碼編譯成可執(zhí)行的二進制文件。為了讓操作系統(tǒng)/引導程序找到程序的開頭,需要定義這樣一個函數(shù)。
簡而言之,需要在大量可執(zhí)行的代碼中定義一個至關(guān)重要的的開頭。
不難看出,對于這些語言來說,main函數(shù)是不可或缺的組成部分。
但是,當我們把目光轉(zhuǎn)向Python時,就會發(fā)現(xiàn)情況大不相同。
Python是一種解釋語言,即腳本語言。運行過程是從上到下,逐行進行的,這意味著它的起點是已知的。
每個.py文件都是一個可執(zhí)行文件,可作為整個程序的入口文件,意味著該程序的入口很靈活,而且無需遵循任何約定。
有時運行Python項目時不需要有指定入口文件(命令行比較常見,例如“ python -m http.server 8000”),可能是因為該項目中有main.py文件,在軟件包中作為“文件”來執(zhí)行。?
總而言之,Python作為腳本語言不同于編譯語言。無論是單個模塊(即.py文件),還是由多個模塊組成的軟件包,Python都可以選擇一種靈活的執(zhí)行方法,這完全不像其他語言那樣必須定義入口。
換句話說,Python不需要規(guī)定程序員必須在語法上定義一個統(tǒng)一的入口(無論是函數(shù)、類還是其他東西)。
有些學生可能會感到困惑,因為他們經(jīng)常看到或編寫以下代碼:
# main filedef main():……if __name__ == '__main__':main()
這不就是Python的main函數(shù)嗎?相信很多人都這么認為!
不,并不是。
除了函數(shù)名是“main”之外,這段代碼與我們前面介紹的main函數(shù)沒有半點關(guān)系,這個函數(shù)既不是必須的,也不能確定程序的執(zhí)行順序。即便沒有上面這樣的main函數(shù),也不會有任何的語法問題。
人們想編寫一個main函數(shù)的主要原因其實是為了強調(diào)這是一個主函數(shù),希望人為地將其設(shè)置成第一個執(zhí)行的函數(shù)。
他們可能認為這個名字的函數(shù)更容易記住。
他們之所以要編寫__name__ =='__main__',可能是因為想表明main()只在直接執(zhí)行當前腳本時才運行,而在將其導入到其他模塊時不要運行。
但是,我個人不推薦這種寫法。
舉一個簡單的例子,假設(shè)只有幾十行代碼,或者一個腳本文件實現(xiàn)了一個簡單的功能(一個爬蟲,或畫一只烏龜,等等),但都是按照前面的方式編寫的。
不推薦if __name__ == '__main__'的寫法,因為:
首先,如果只有一個文件的話,那么這個文件不可能被導出。
其次,如果有多個文件,強烈建議不要將這個語句寫在入口文件(main.py)中。從理論上講,它的內(nèi)容不應(yīng)該導出供其他模塊使用,因為它是起點。
最后,在多個文件的情況下,也不建議在非入口的文件中寫入這條語句,因為這條語句能做的最多也就是編寫一些測試代碼。即便如此,測試代碼也應(yīng)分開寫到專用目錄或文件中。
每次看到這些笨拙的代碼時,我都會感到不適。為什么要寫這樣的if語句?你壓根不應(yīng)該將這段代碼包裝成一個函數(shù)!
總結(jié)
打破慣性思維,編寫真實的代碼。main函數(shù)是某些語言的唯一入口,但不應(yīng)在Python中使用。你應(yīng)該了解腳本語言的特征,并學習簡單而優(yōu)雅的風格。
你可以使用main.py,而不是編寫main函數(shù)。由于Python程序的執(zhí)行單元是腳本文件,而不是函數(shù)或類,因此建議將入口文件命名為main.py,并根據(jù)需要決定內(nèi)部的函數(shù)。
將main.py作為入口文件。該文件可直接與命令行的“-m”參數(shù)結(jié)合使用。
——End——
后臺回復關(guān)鍵字:1024,獲取一份精心整理的技術(shù)干貨 后臺回復關(guān)鍵字:進群,帶你進入高手如云的交流群。 推薦閱讀
這是一個能學到技術(shù)的公眾號,歡迎關(guān)注
