美文网首页python百例
117-可变与不可变对象的效率

117-可变与不可变对象的效率

作者: 凯茜的老爸 | 来源:发表于2018-09-19 13:53 被阅读8次

    python是一种解释型的语言,执行效率要比C这样的编译型语言差得多,但是也应该注意它的效率。
    python的各种数据类型,按更新模型可以分为可变类型(如列表、字典)和不可变类型(如数字、字符串和元组)。多使用可变类型,它的执行效率比不可变类型要高。
    在《37-生成密码/验证码》中,将结果保存到了一个名为 result 的变量中。result 是字符串,字符串不可变,所以python在工作时,首先要申请一段内存储 result 的初值(空串''),随机取得一个字符后(如'a'),result += 'a'实际上是要重新申请一个新的内存,把新字符串存储进去。如此往复,有几次循环,就要重新分配几次内存。
    如果变量 result 使用列表,只需要为其分配一次内存即可,因为列表是可变的。代码可以更改为以下样式:

    from random import choice
    import string
    
    all_chs = string.ascii_letters + string.digits  # 大小写字母加数字
    
    def gen_pass(n=8):
        result = []
    
        for i in range(n):
            ch = choice(all_chs)
            result.append(ch)
    
        return ''.join(result)
    
    if __name__ == '__main__':
        print(gen_pass())
        print(gen_pass(4))
        print(gen_pass(10))
    

    相关文章

      网友评论

      • 619b2ba3709a:张老师您好,这一段代码,我还是体会不到可变与不可变对象的效率呀?感觉就是随机生成几个字符。可以给我解析一下麻?
        619b2ba3709a:@凯茜的老爸 好的!谢谢!:sunflower:
        凯茜的老爸:这么小的程序看不出来效率的。脑海中要有内存的概念,看看我那些描述吧。

      本文标题:117-可变与不可变对象的效率

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