python的list添加元素,为什么append的效率比“+”高

 我来答
tufeididi007
2018-02-20 · TA获得超过2125个赞
知道大有可为答主
回答量:2698
采纳率:76%
帮助的人:1249万
展开全部

+只不过是用魔法函数__add__实现了一次, 原生的应该还是append或者insert

你可以实现一个很简单的对象

>>> class List:
def __init__(self, lst):
if isinstance(lst, (list, tuple)):
self.v = list(lst)
else:
raise TypeError("无法识别的类型")
def __add__(self, lst):
if isinstance(lst, (list, tuple)):
self.v.extend(lst)
else:
raise TypeError("无法识别的类型")


>>> a = List([1, 2])
>>> a.v
[1, 2]
>>> a + [3]
>>> a.v
[1, 2, 3]
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式