习惯了其它语言开发方式,可能会对Python中全局变量不被共享的感到困惑。“Python中全局变量不被共享”其实是不存在的,造成这个“感觉”的原因是没意识到多进程环境的存在。
在Web领域使用较多的Java平台上,一个Web站点启动后可能就只有一个进程,程序环境很可能是一个进程+多个线程,此时全局变量的变更很自然被程序里的所有代码看到。
来到CPython世界,由于GIL(全局解释器锁)的存在,无法充分利用CPU的利用效率,生产部署的时候会采用多进程的机制,也就是启动多个CPython来充分使用硬件资源,这里的环境成为了多进程环境,涉及进程间通信,在一个进程里修改的全局变量也自然仅仅限于当前进了,当Python环境本身没有GIL,如Jython、IronPython,也就不会有“Python全局变量不被共享”的错觉了。
CPython常用的多进程部署:
Java典型的单进程部署: