Отвечая на другой вопрос , я предложил использовать timeit
для проверки разницы между индексацией списка с положительными целыми числами или целыми отрицательными целями. Здесь код:
import timeit
t=timeit.timeit('mylist[99]',setup='mylist=list(range(100))',number=10000000)
print (t)
t=timeit.timeit('mylist[-1]',setup='mylist=list(range(100))',number=10000000)
print (t)
Я запустил этот код с помощью python 2.6:
$ python2.6 test.py
0.587687015533
0.586369991302
Затем я запустил его с помощью python 3.2:
$ python3.2 test.py
0.9212150573730469
1.0225799083709717
Затем я почесал голову, сделал небольшой поиск в Google и решил опубликовать эти наблюдения здесь.
Операционная система: OS-X (10.5.8) - Intel Core2Duo
Это кажется довольно значительной разницей для меня (фактор более чем 1,5 разницы). У кого-нибудь есть идея, почему python3 намного медленнее - особенно для такой общей операции?
ИЗМЕНИТЬ
Я запустил тот же код на своем рабочем столе Ubuntu Linux (Intel i7) и добился сопоставимых результатов с python2.6 и python 3.2. Похоже, что это проблема, которая зависит от операционной системы (или процессора) (другие пользователи видят то же поведение на машинах Linux - см. Комментарии).
РЕДАКТИРОВАТЬ 2
В одном из ответов был запрошен баннер запуска, так что:
Python 2.6.4 (r264:75821M, Oct 27 2009, 19:48:32)
[GCC 4.0.1 (Apple Inc. build 5493)] on darwin
и
Python 3.2 (r32:88452, Feb 20 2011, 10:19:59)
[GCC 4.0.1 (Apple Inc. build 5493)] on darwin
UPDATE
Я только что установил новые версии python2.7.3 и python3.2.3 из http://www.python.org/download/
В обоих случаях я взял
"Python x.x.3 32-разрядный i386/PPC-инсталлятор Mac OS X (для Mac OS X 10.3 по 10.6 [2])"
так как я на OS X 10.5. Вот новые тайминги (которые разумно согласованы с помощью нескольких испытаний):
python 2.7
$python2.7 test.py
0.577006101608
0.590042829514
python 3.2.3
$python3.2 test.py
0.8882801532745361
1.034242868423462