Python 没有main函数的原因


Posted in Python onJuly 10, 2020

毫无疑问 Python 中没有所谓的 main 入口函数,但是网上经常看到一些文章提“Python 的 main 函数”、“建议写 main 函数”……

有些人是知情的,他的意图可能是模仿那些正宗的 main 函数,但还有不少人明显是被误导了(或自己误解了),就写出来很累赘的代码。

本期“Python 为什么”栏目来聊聊 Python 为什么没有 main 函数

在开始正题之前,先要来回答这两个问题:所谓的 “main 函数”是指什么?为什么有些编程语言需要强制写一个 main 函数?

某些编程语言以 main 函数作为程序的执行入口,例如 C/C++、C#、 Java、Go 和 Rust 等,它们具有特定的含义:

  • main 函数名是强制的,也就是要求必须有一个 main 函数
  • main 函数最多只能有一个,也就是说程序的入口是唯一的
  • 语法格式有一定的要求,具有相对固定的模板

为什么要强制一个 main 入口函数呢?

这些语言是编译型语言,需要把代码编译成可执行的二进制文件,为了让操作系统/启动器找到程序的起点,所以要约定这一个函数。简单地说,就是在一大堆代码里,需要定义一个显著的可用于执行的开头。

不难看出,main 函数是那些语言中重要而不可缺的有机组成部分。

然而,我们再来看看 Python,情况就大不相同了。

  • Python 是解释型语言,即脚本语言,运行过程是从上往下,逐行解析运行,也就是说它的起点是可知的
  • 每个 .py 文件就是一个可执行文件,都可作为整个程序的入口文件,也就是说程序的入口是灵活可变的,没有必须遵守的约定
  • 有时候运行 Python 项目,并没有指定入口文件(命令行中较常见,例如"python -m http.server 8000"), 那可能是存在 __main__.py 文件,它所在的包被当成一个“文件”来执行了

归结起来,意思是说 Python 这种脚本语言跟编译型语言不同,它不管是在单个模块层面(即一个 .py 文件),还是在由多个模块组成的包层面,都可选择灵活的执行方式,不像其它语言缺了约定好的入口就没法执行。

也就是说,Python 没有必要在语法层面规定程序员必须定义出一个统一的入口(不管是函数还是类还是什么东西)。

有些同学可能会有疑惑,因为他们经常看到或者自己写出下面这样的代码:

# main 里是某些主体代码
def main():
 …… 
 
if __name__ == '__main__':
 main()

难道这不就是 Python 的 main 函数么?相信有不少同学会这么想!

非也!非也!

除了函数名是“main”以外,它跟我们前面介绍的正统的 main 函数没有半毛钱关系,既没有强制性,也没有必然决定程序执行顺序的作用。缺少它,也不会导致什么语法问题。

之所以有些知情人要命名出一个”main“函数,其实是想强调它的”主要“地位,想要人为地安排它作为第一个执行的函数。他们可能认为这样命名的函数,比较容易记忆。

之所以有些知情人要写if __name__ == '__main__' ,可能想表明 main() 只有在当前脚本被直接执行时才运行,不希望被导入其它模块时运行。

对于这些“知情人”,他们有一定的道理。

但是,我个人并不推荐这种写法,甚至有时候会非常反感!

最明显的例子:明明只有几十行代码,或者仅有一个脚本文件,实现一个简单的功能(一小段爬虫、用 turtle 画张图等等),但是它们都按前面的样式写了。

我每次看到这种不假思索的累赘代码,就觉得难受。为什么要写那行 if 语句呢?可能的话,应该拆分 main 函数,甚至不必封装成一个函数啊!

我个人总结出以下的经验:

  • 打破惯性思维,写出地道的代码。main 入口函数是某些语言特有的,不该在 Python 中“照猫画虎”,应该了解脚本语言的特点,写出简洁优雅的风格
  • 使用 main.py 而非 main()。因为 Python 的程序执行单位其实是脚本文件,而非某个函数或者类,所以建议把入口文件命名为 main.py,内部的函数按需求而定
  • 可以的话,使用__main__.py 作为入口文件。这个文件结合命令行的“-m”参数使用,非常好用。推荐阅读:为什么是 Python -m
  • 不推荐写if __name__ == '__main__' 。首先,如果只有一个文件的话,因为不存在导出的可能,不建议写。其次,存在多文件时,入口文件(main.py)中极不推荐写这一句,此文件的代码逻辑应该精炼,理论上其内容不该被导出到其它模块使用,因为它是起点!最后,多文件的非入口文件也不建议写,因为在非入口文件中写这个判断,最大的作用就是写一些测试代码,但是测试代码应该分离出来,写到专门的目录或文件中。

小结:本文首先解释了什么是 main 入口函数,以及为什么某些语言会强制要求写 main 函数;接着,解释了为什么 Python 不需要写 main 函数;最后则是针对某些人存在的惯性误区,分享了我个人的四点编程经验。

以上就是Python 没有main函数的原因的详细内容,更多关于Python main函数的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
跟老齐学Python之私有函数和专有方法
Oct 24 Python
简单介绍利用TK在Python下进行GUI编程的教程
Apr 13 Python
在Python中处理列表之reverse()方法的使用教程
May 21 Python
Python时间模块datetime、time、calendar的使用方法
Jan 13 Python
Python实现的爬虫功能代码
Jun 24 Python
python 从文件夹抽取图片另存的方法
Dec 04 Python
Python API自动化框架总结
Nov 12 Python
python json.dumps中文乱码问题解决
Apr 01 Python
关于tf.matmul() 和tf.multiply() 的区别说明
Jun 18 Python
Python 常用日期处理 -- calendar 与 dateutil 模块的使用
Sep 02 Python
pycharm中leetcode插件使用图文详解
Dec 07 Python
python基础学习之递归函数知识总结
May 26 Python
如何教少儿学习Python编程
Jul 10 #Python
Django def clean()函数对表单中的数据进行验证操作
Jul 09 #Python
django form和field具体方法和属性说明
Jul 09 #Python
浅谈Python里面None True False之间的区别
Jul 09 #Python
Django中Q查询及Q()对象 F查询及F()对象用法
Jul 09 #Python
在CentOS7下安装Python3教程解析
Jul 09 #Python
django 将自带的数据库sqlite3改成mysql实例
Jul 09 #Python
You might like
「OVERLORD」动画重要删减!雅儿贝德的背叛?至尊猎杀队结成
2020/04/09 日漫
如何取得中文字符串中出现次数最多的子串
2013/08/08 PHP
PHP检查端口是否可以被绑定的方法示例
2018/08/09 PHP
你可能不再需要JQUERY
2021/03/09 Javascript
javascript 动态数据下的锚点错位问题解决方法
2008/12/24 Javascript
制作高质量的JQuery Plugin 插件的方法
2010/04/20 Javascript
ie浏览器使用js导出网页到excel并打印
2014/03/11 Javascript
JS实现简单的顶部定时关闭层效果
2014/06/15 Javascript
JavaScript中的变量定义与储存介绍
2014/12/31 Javascript
JavaScript实现的类字典插入或更新方法实例
2015/07/10 Javascript
jQuery 3.0中存在问题及解决办法
2016/07/15 Javascript
vue2.0实现导航菜单切换效果
2017/05/08 Javascript
微信小程序+云开发实现欢迎登录注册
2019/05/24 Javascript
js判断复选框是否选中的方法示例【基于jQuery】
2019/10/10 jQuery
vue实现点击追加选中样式效果
2019/11/01 Javascript
nodejs中使用archive压缩文件的实现代码
2019/11/26 NodeJs
[03:02]辉夜杯主赛事第二日 每日之星
2015/12/27 DOTA
[40:03]RNG vs VG 2019国际邀请赛小组赛 BO2 第二场 8.15
2019/08/17 DOTA
Python实现批量将word转html并将html内容发布至网站的方法
2015/07/14 Python
win10环境下python3.5安装步骤图文教程
2017/02/03 Python
Python双精度浮点数运算并分行显示操作示例
2017/07/21 Python
Flask和Django框架中自定义模型类的表名、父类相关问题分析
2018/07/19 Python
Python面向对象之类和对象实例详解
2018/12/10 Python
python写日志文件操作类与应用示例
2019/07/01 Python
Django 实现xadmin后台菜单改为中文
2019/11/15 Python
通过实例解析Python文件操作实现步骤
2020/09/21 Python
Python实现我的世界小游戏源代码
2021/03/02 Python
实例教程 利用html5和css3打造一款创意404页面
2014/10/20 HTML / CSS
AmazeUI 等分网格的实现示例
2020/08/25 HTML / CSS
Lookfantastic俄罗斯:欧洲在线化妆品零售商
2019/08/06 全球购物
大学班长的职责
2014/01/27 职场文书
ktv中秋节活动方案
2014/01/30 职场文书
幼儿园小班评语
2014/04/18 职场文书
机械电子工程专业求职信
2014/06/22 职场文书
行政经理岗位职责
2015/04/15 职场文书
我的法兰西岁月观后感
2015/06/09 职场文书