本人初学python, 遇到了如下这么一段代码, 根据运行的结果思考了一下, 不知道理解对不对.
版本为python3.6
代码如下:
def g(p): z = p.pop(0) p.extend(z) return p y = ['h', 'i', 'j'] g(y).extend(g(y[:])) print(y) # -> ['i', 'j', 'h', 'j', 'h', 'i']
个人理解如下:
首先运行g(y), 由于按引用传递(不知道这么表述对不对?), 该函数直接在y上面进行修改, 此时y变成了['i', 'j', 'h'].
此时运行后面的.extend(g(y[:])). 首先拷贝一份y的数据, y此时没变, 然后进行g(y[:])操作, 该操作将y[:]变为['j', 'h', 'i']
最后进行extend()操作, y和y[:]合并, 得到最后结果为['i', 'j', 'h', 'j', 'h', 'i']
不知道上述理解是否有误, 恳请前辈指点一下, 不胜感激!
同时刚刚在撰写问题的时候想到的另外一个问题:
为什么不可以先运行g(y[:])部分? 如果先运行这一部分的话, 最后得到的结果应该是['i', 'j', 'h', 'i', 'j', 'h']. 但是解释器给的答案还是上面的, 所以对于这一问题疑惑概括为:
如果有a.extend(b)那么是先运行a还是先运行b, 为什么?
问题更新了一下, 望有前辈能解答, 不胜感激!
慕姐8265434
相关分类