
PyPy速度不如CPython的情况分析
并非所有情况下PyPy都比CPython快。某些特定场景下,PyPy的执行速度反而会慢于CPython。以下代码示例可以说明这种情况:
这段代码中,PyPy的运行速度低于CPython。
import hashlib
from pathlib import Path
import random
def get_string_md5(text: str) -> str:
md5_encoder = hashlib.md5()
md5_encoder.update(text.encode('utf-8'))
return md5_encoder.hexdigest()
def tt():
a = [
get_string_md5(f'哈哈{random.randint(1, 100)}')
for _ in range(10000000)
]
assert 'dhquiwd' not in a
原因如下:
立即学习“Python免费学习笔记(深入)”;
- 即时编译开销: PyPy采用即时编译(JIT)技术,将RPython代码(Python的一个子集)编译成机器码。对于短小的代码片段,JIT编译的开销可能超过执行本身节省的时间,导致整体速度变慢。
- 垃圾回收差异: PyPy和CPython的垃圾回收机制不同。在某些情况下,PyPy的垃圾回收策略可能会导致性能下降。
总而言之,PyPy在需要多次执行的代码中表现出色,可以显著提升效率。然而,对于短小或只执行一次的代码片段,PyPy的JIT编译开销和垃圾回收机制可能会导致其性能不如CPython。











