• Python的16个“坑”


    1. 不要使用可变对象作为函数默认值

    代码如下:
    这2个例子说明了什么? 字典,集合,列表等等对象是不适合作为函数默认值的. 因为这个默认值实在函数建立的时候就生成了, 每次调用都是用了这个对象的”缓存”. 我在上段时间的分享python高级编程也说到了这个问题,这个是实际开发遇到的问题,好好检查你学过的代码, 也许只是问题没有暴露。

    可以这样改,代码如下:

    2. 生成器不保留迭代过后的结果

    代码如下:

    3. lambda在闭包中会保存局部变量

    代码如下:
    In [29]: my_list = [lambda: i for i in range(5)]
     
    In [30]: for l in my_list:
       ....:         print(l())
       ....:
    4
    4

    这个问题还是上面说的python高级编程中说过具体原因. 其实就是当我赋值给my_list的时候,lambda表达式就执行了i会循环,直到 i =4,i会保留

    但是可以用生成器,代码如下:

    也可以坚持用list,代码如下:

    有点不好懂是吧,在看看python的另外一个魔法,代码如下:

    一个分组的函数,看起来很不好懂,对吧? 我们来解析下这里

    代码如下:

    4. 在循环中修改列表项

    代码如下:

    思考一下,为什么 – 是因为你对列表的remove,影响了它的index

    代码如下:

    5. IndexError – 列表取值超出了他的索引数

    代码如下:

    6. 重用全局变量

    代码如下:

    7. 拷贝可变对象

    代码如下:

    8. python多继承

    代码如下:

    看起来都是很简单, 有次序的从底向上,从前向后找,找到就返回. 再看例子:

    代码如下:

    这也就涉及了MRO(Method Resolution Order):

    代码如下:

    MRO的算法有点小复杂,既不是深度优先,也不是广度优先

    9. 列表的+和+=, append和extend

    代码如下:

    10. datetime也有布尔值

    这是一个坑,代码如下:

    11. ‘==’ 和 is 的区别

    我的理解是”is”是判断2个对象的身份, ==是判断2个对象的值,代码如下:

    12. 浅拷贝和深拷贝

    我们在实际开发中都可以向对某列表的对象做修改,但是可能不希望改动原来的列表. 浅拷贝只拷贝父对象,深拷贝还会拷贝对象的内部的子对象,代码如下:

    13. bool其实是int的子类

    代码如下:

    14. 元组是不是真的不可变?

    代码如下:

    这里有个不错的解释Python’s += Is Weird, Part II :

    代码如下:

    15. python没有私有方法/变量? 但是可以有”伪”的

    代码如下:

    16. 异常处理加else

    代码如下:
  • 相关阅读:
    C#之类和对象
    uml中关联与依赖
    uml中的各个关系
    数据挖掘聚类算法分类(转)
    (转)Client http persistent connection limit
    牛客网NOIP赛前集训营提高组(第七场)Solution
    训练题表
    CF1000赛后总结
    UVA3983 Robotruck 题解
    CF1034A Enlarge GCD
  • 原文地址:https://www.cnblogs.com/Vito2008/p/5018525.html
Copyright © 2020-2023  润新知