推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
est
V2EX  ›  Python

PyCon 2016: 如何优雅地黑 GIL

  •  1
     
  •   est ·
    est · Jun 6, 2016 · 3778 views
    This topic created in 3652 days ago, the information mentioned may be changed or developed.

    python 如此强大,可以调用你的计算机的几乎所有资源:

    视频: https://www.youtube.com/watch?v=P3AyI_u66Bw

    9 replies    2016-06-06 10:36:21 +08:00
    fy
        1
    fy  
       Jun 6, 2016
    蛤蛤蛤 这个视频我也看了,台上在讲:
    现在我们的电脑变得牛逼了, Python 可以使用这些资源 ... 然后一个一个点出来

    除了…… 8 cores

    台下传来笑声
    FrankFang128
        2
    FrankFang128  
       Jun 6, 2016
    请教为什么不能 8 cores
    tutuge
        3
    tutuge  
       Jun 6, 2016 via iPhone
    @FrankFang128 全局解释器锁导致的
    fy
        4
    fy  
       Jun 6, 2016
    @FrankFang128 因为 GIL 会以指令为单位加锁,所以计算密集型程序用不了 8 个核心的运算力。不过这不意味着 Python 中多线程没用,等 IO 还是可以利用多线程的。
    clino
        5
    clino  
       Jun 6, 2016
    所以我之前有个设计是把需要多核完成的部分专门弄到一个多进程的服务里然后用 rpc 接口方式提供出来给别的 python 模块使用
    shimmerh
        6
    shimmerh  
       Jun 6, 2016
    这个问题,其实是设计者为了方便开发者所考虑的。可惜大家不知足啊。。
    tutuge
        7
    tutuge  
       Jun 6, 2016 via iPhone
    @clino 为啥不直接用 python 的多进程…
    clino
        8
    clino  
       Jun 6, 2016
    @tutuge 因为使用的模块是 web 服务,部署方式是用 gevent 方式跑的,只有单进程单线程在跑
    ipconfiger
        9
    ipconfiger  
       Jun 6, 2016
    import multiprocessing
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   3028 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 98ms · UTC 08:42 · PVG 16:42 · LAX 01:42 · JFK 04:42
    ♥ Do have faith in what you're doing.