2014-06-19 03:20:34 +03:00
|
|
|
# Function call overhead test
|
|
|
|
# Perform the same trivial operation as calling function, cached in a
|
|
|
|
# local variable. This is commonly known optimization for overly dynamic
|
|
|
|
# languages (the idea is to cut on symbolic look up overhead, as local
|
|
|
|
# variables are accessed by offset, not by name)
|
|
|
|
import bench
|
|
|
|
|
2021-03-15 19:27:36 +05:30
|
|
|
|
2014-06-19 03:20:34 +03:00
|
|
|
def f(x):
|
|
|
|
return x + 1
|
|
|
|
|
2021-03-15 19:27:36 +05:30
|
|
|
|
2014-06-19 03:20:34 +03:00
|
|
|
def test(num):
|
|
|
|
f_ = f
|
|
|
|
for i in iter(range(num)):
|
|
|
|
a = f_(i)
|
|
|
|
|
2021-03-15 19:27:36 +05:30
|
|
|
|
2014-06-19 03:20:34 +03:00
|
|
|
bench.run(test)
|