美文网首页
Python缓存重用机制

Python缓存重用机制

作者: 卓尔不群的雅典 | 来源:发表于2020-06-02 22:38 被阅读0次

    Python 缓冲机制是为提高程序执行的效率服务的,实际上就是在 Python 解释器启动时从内存空间中开辟出一小部分,用来存储高频使用的数据,这样可以大大减少高频使用的数据创建时申请内存和销毁时撤销内存的开销。

    Python 在存储数据时,会根据数据的读取频繁程度以及内存占用情况来考虑,是否按照一定的规则将数据存储缓存中。那么问题来了,内存重用机制适用于哪些基本数据类型呢?

    表 1 罗列了 Python 是否将指定数据存入缓存中的规则:


    image.png

    下面直接通过一段程序来演示 Python 缓存机制的规则。

    1.  #范围在 [-5, 256] 之间的小整数
    2.  int1 = -5
    3.  int2 = -5
    4.  print("[-5, 256] 情况下的两个变量:", id(int1), id(int2))
    
    6.  #bool类型
    7.  bool1 = True
    8.  bool2 = True
    9.  print("bool类型情况下的两个变量:",id(bool1),id(bool2))
    
    11.  #对于字符串
    12.  s1 = "3344"
    13.  s2 = "3344"
    14.  print("字符串情况下的两个交量", id(s1), id(s2))
    
    16.  #大于 256 的整数
    17.  int3 = 257
    18.  int4 = 257
    19.  print("大于 256 的整数情况下的两个变量", id(int3), id(int4))
    
    21.  #大于 0 的浮点数
    22.  f1 = 256.4
    23.  f2 = 256.4
    24.  print("大于 0 的浮点数情况下的两个变量", id(f1), id(f2))
    
    26.  #小于 0 的浮点数
    27.  f3 = -2.45
    28.  f4 = -2.45
    29.  print("小于 0 的浮点数情况下的两个变量", id(f3), id(f4))
    
    31.  #小于 -5 的整数
    32.  n1 = -6
    33.  n2 = -6
    34.  print("小于 -5 的整数情况下的两个变量", id(n1), id(n2))
    

    注意,此程序中,大量使用 id() 内置函数,该函数的功能是获取变量(对象)所在的内存地址。运行该程序,其输出结果为:

    [-5, 256] 情况下的两个变量: 1792722416 1792722416
    bool类型情况下的两个变量: 1792241888 1792241888
    字符串情况下的两个交量 2912801330712 2912801330712
    大于 256 的整数情况下的两个变量 2912801267920 2912801267920
    大于 0 的浮点数情况下的两个变量 2912762210728 2912762210728
    小于 0 的浮点数情况下的两个变量 2912762211016 2912762211040
    小于 -5 的整数情况下的两个变量 2912801267952 2912801267984

    以上输出结果中,每行都输出了 2 个相对应的变量所在的内存地址,如果相等,则表明 Python 内部对其使用了缓存机制,反之则没有。读者可对照以上输出结果来理解表 1 中有关变量缓存机制的规则。

    另外,对于表 1 中所提到的代码块,Python 中的函数和类都被认为是在程序中开辟了一块新的代码块。以函数为例,函数内部的代码分属一个代码块,函数外部的代码属于另一个代码块。

    有关函数的具有用法,后续章节会详细介绍,这里读者只需要知道函数中包含的代码,属于一个新的代码块即可。

    由表 1 可以看到,Python 缓存机制在不同的代码块中也会有不同的表现。举一个例子,在上面例子代码的基础上,继续编写如下程序:

    1.  def fun():
    2.  #[-5,256]
    3.  int1 = -5
    4.  print("fun中 -5 的存储状态",id(int1), id(int2))
    
    6.  #bool类型
    7.  bool3 = True
    8.  print("fun中 bool 类型的存储状态",id(bool3),id(bool2))
    
    10.  #字符串类型
    11.  s1 = "3344"
    12.  print("fun 中 3344 字符串的存储状态", id(s1), id(s2))
    
    14.  #大于 256
    15.  int3 = 257
    16.  print("fun中 257 的存储状态", id(int3), id(int4))
    
    18.  #浮点类型
    19.  f1 = 256.4
    20.  print("fun 中 256.4 的存储状态",id(f1), id(f2))
    
    22.  #小于 -5
    23.  n1 = -6
    24.  print("fun 中 -6 的存储状态", id(n1), id(n2))
    
    26.  fun()
    

    输出结果为:

    fun中 -5 的存储状态 1792722416 1792722416
    fun中 bool 类型的存储状态 1792241888 1792241888
    fun 中 3344 字符串的存储状态 1976405206496 1976405206496
    fun中 257 的存储状态 1976405225648 1976405225680
    fun 中 256.4 的存储状态 1976394459752 1976394459872
    fun 中 -6 的存储状态 1976404744880 1976405225744
    

    根据输出结果可以分析出:

    1. 从 -5 、bool 类型以及字符串 "3344" 的输出结果可以得知,无论是在同一代码块,还是不同的代码块,它们都使用相同的缓存内容;
    2. 从 257 和 256.4 的输出结果可以得知,如果位于同一代码块,则使用相同的缓存内容;反之,则不使用;
    3. 从 -6 的输出结果得知,Python 没有对其缓存进行操作。

    笔记来源C语言中文网 http://c.biancheng.net/view/4186.html

    相关文章

      网友评论

          本文标题:Python缓存重用机制

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