python - 在递归函数中将巨大的列表作为参数传递时的性能?

标签 python performance recursion argument-passing

我正在使用 Python,我有一个递归函数,它接受一个巨大的列表作为参数之一:

# Current implementation
def MyFunction(arg1, arg2, my_huge_list)
    ...
    ...
    MyFunction(new_arg1, new_arg2, my_huge_list)

正如您在上面看到的,MyFunction 是使用 same 列表 my_huge_list 递归调用的;与其他论点不同,这不会改变。而且,这个列表又是巨大的。我的一个 friend 建议我可以将 my_huge_list 视为全局变量以提高性能,否则这个巨大的列表可能会在每次迭代中被一遍又一遍地复制。

# Friend's suggestion

MyHugeList=[a,b,c, ...and many many other elements... ]

def MyFunction(arg1, arg2)
    global MyHugeList
    ...
    ...
    MyFunction(new_arg1, new_arg2)

使用如上所示的全局变量是否可以提高算法的性能而不是原始版本?我的程序运行了数周,因此从长远来看,即使是微小的改进也可能很有值(value)。

最佳答案

列表将通过引用传递,因此与 100000 项列表相比,传输 1 项列表不会花费更长的时间:

def null(x): return x
longlist = range(100000)
shortlist = range(1)
longerlist = range(1000000)

%timeit null(shortlist)
10000000 loops, best of 3: 124 ns per loop

%timeit null(longlist)
10000000 loops, best of 3: 137 ns per loop

%timeit null(longerlist)
10000000 loops, best of 3: 125 ns per loop

较长的列表中有 100k 和 1M 的条目,但与较短的列表相比,作为参数传递的时间并不长。

可能还有其他方法可以提高性能;这可能不是其中之一。

关于python - 在递归函数中将巨大的列表作为参数传递时的性能?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19187785/

相关文章:

python - 如何测量 tensorflow 中的困惑度?

python - CosmosDB 和 Python3 : how to query?

python - 使用 Suds 的 Soap 客户端

python - 如何覆盖 pandas DataFrame 中的数组单元格?

python - 在 Pandas 中有效地聚合重新采样的日期时间集合

python - 有人可以解释双重递归 python 吗?

javascript - 如何编写递归函数来获取某个范围内的值?

node.js - 使用多个 Heroku 应用程序对 Nginx 进行负载平衡

MySQL 更快的 INSERT

python - 从Python中的递归函数返回