美文网首页
私有化 生成器

私有化 生成器

作者: 蓝色海洋_bd2b | 来源:发表于2018-09-24 19:04 被阅读0次

    私有化
    xx: 公有变量
    _x: 单前置下划线,私有化属性或方法,from somemodule import *禁止导入,类对象和子类可以访问
    _xx:双前置下划线,避免与子类中的属性命名冲突,无法在外部直接访问(名字重整所以访问不到)
    xx:双前后下划线,用户名字空间的魔法对象或属性。例如:init , __ 不要自己发明这样的名字
    xx
    :单后置下划线,用于避免与Python关键词的冲突
    通过name mangling(名字重整(目的就是以防子类意外重写基类的方法或者属性)如:_Class__object)机制就可以访问private了

    父类中属性名为名字的,子类不继承,子类不能访问
    如果在子类中向
    名字赋值,那么会在子类中定义的一个与父类相同名字的属性
    _名的变量、函数、类在使用from xxx import *时都不会被导入

    生成器
    1、什么是生成器通过列表生成式,我们可以直接创建一个列表。但是,受到内存限制,列表容量肯定是有限的。而且,创建一个包含100万个元素的列表,不仅占用很大的存储空间,如果我们仅仅需要访问前面几个元素,那后面绝大多数元素占用的空间都白白浪费了。所以,如果列表元素可以按照某种算法推算出来,那我们是否可以在循环的过程中不断推算出后续的元素呢?这样就不必创建完整的list,从而节省大量的空间。在Python中,这种一边循环一边计算的机制,称为生成器:generator。
    2、 创建生成器方法1
    要创建一个生成器,有创建 L 和 G 的区别仅在于最外层的 [ ] 和 ( ) , L 是一个列表,而 G 是一个生成器。我们可以直接打印出L的每一个元素,但我们怎么打印出G的每一个元素呢?如果要一个一个打印出来,可以通过 next() 函数获得生成器的下一个返回值:很多种方法。第一种方法很简单,只要把一个列表生成式的 [ ] 改成 ( )生成器保存的是算法,每次调用 next(G) ,就计算出 G 的下一个元素的值,直到计算到最后一个元素,没有更多的元素时,抛出 StopIteration 的异常。当然,这种不断调用 next() 实在是太变态了,正确的方法是使用 for 循环,因为生成器也是可迭代对象。所以,我们创建了一个生成器后,基本上永远不会调用 next() ,而是通过 for 循环来迭代它,并且不需要关心 StopIteration 异常。

    1. 创建生成器方法2enerator非常强大。如果推算的算法比较复杂,用类似列表生成式的 for 循环无法实现的时候,还可以用函数来实现。
      比如,著名的斐波拉契数列(Fibonacci),除第一个和第二个数外,任意一个数都可由前两个数相加得到:
      1, 1, 2, 3, 5, 8, 13, 21, 34, …
      斐波拉契数列用列表生成式写不出来,但是,用函数把它打印出来却很容易:仔细观察,可以看出,fib函数实际上是定义了斐波拉契数列的推算规则,可以从第一个元素开始,推算出后续任意的元素,这种逻辑其实非常类似generator。

    2. send例子:执行到yield时,gen函数作用暂时保存,返回i的值;temp接收下次c.send(“python”),send发送过来的值,c.next()等价c.send(None) 使用next函数 使用next()方法 使用send

    总结
    生成器是这样一个函数,它记住上一次返回时在函数体中的位置。对生成器函数的第二次(或第 n 次)调用跳转至该函数中间,而上次调用的所有局部变量都保持不变。
    生成器不仅“记住”了它数据状态;生成器还“记住”了它在流控制构造(在命令式编程中,这种构造不只是数据值)中的位置。
    生成器的特点:
    1.节约内存
    2.迭代到下一次的调用时,所使用的参数都是第一次所保留下的,即是说,在整个所有函数调用的参数都是第一次所调用时保留的,而不是新创建的。

    相关文章

      网友评论

          本文标题:私有化 生成器

          本文链接:https://www.haomeiwen.com/subject/pgrhoftx.html