And*_*rew 7 python windows debugging cpu pyglet
我正在使用python的pyglet模块(Windows上的python 3).当我引用pyglet.image中的任何类时,python的CPU使用率会跳起来并且在我退出python之前不会下降.例如:
Microsoft Windows [Version 6.1.7601]
Copyright (c) 2009 Microsoft Corporation. All rights reserved.
C:\Anaconda3>python.exe
Python 3.4.3 |Anaconda 2.3.0 (64-bit)| (default, Mar 6 2015, 12:06:10) [MSC v.1
600 64 bit (AMD64)] on win32
Type "help", "copyright", "credits" or "license" for more information.
>>> import pyglet #No problem!
>>> pyglet.image.ImageData #Heavy CPU load until I exit python
<class 'pyglet.image.ImageData'>
Run Code Online (Sandbox Code Playgroud)
这是预期的行为吗?为什么提这个类(甚至没有实例化它)会导致如此高的CPU负载?
我测试的系统:
带有Anaconda python 3.4.3的Windows 7桌面和通过'pip install pyglet'安装的pyglet:高CPU使用率(我的问题)
与Anaconda python 3.4.3相同的Win7桌面,但通过'pip install hg + https://bitbucket.org/pyglet/pyglet ' 安装了pyglet :高CPU使用率.
来自python.org的python 3.5的相同Win7桌面和通过'pip install pyglet'安装的pyglet:高CPU使用率.
Fedora 22联想笔记本电脑用python 3.4.2和pyglet 1.2.1通过dnf安装:没问题.
Windows 10惠普笔记本电脑与Anaconda python 3.4和pyglet通过'pip install pyglet'安装:没问题.
这是否可能与硬件有关?
它可能与模块上的以下几行有关:
# Initialise default codecs
from pyglet.image import codecs as _codecs
_codecs.add_default_image_codecs()
Run Code Online (Sandbox Code Playgroud)
加载默认编解码器的顺序是:
# Add the codecs we know about. These should be listed in order of
# preference. This is called automatically by pyglet.image.
# Compressed texture in DDS format
try:
from pyglet.image.codecs import dds
add_encoders(dds)
add_decoders(dds)
except ImportError:
pass
# Mac OS X default: QuickTime
(...)
# Windows XP default: GDI+
(...)
# Linux default: GdkPixbuf 2.0
(...)
# Fallback: PIL
(...)
# Fallback: PNG loader (slow)
(...)
# Fallback: BMP loader (slow)
(...)
Run Code Online (Sandbox Code Playgroud)
因为延迟加载pyglet.image仅在您引用某些内容时才加载,并且您可能正在使用慢速回退之一。如果是这种情况,也许您可以尝试安装/卸载编解码器,以便一次使用一个编解码器,并查明问题是否确实出在编解码器上。发布这些编解码器的版本可能有助于重现该问题。
| 归档时间: |
|
| 查看次数: |
234 次 |
| 最近记录: |