QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 4042|回复: 0
打印 上一主题 下一主题

[国赛经验] Python 代码块、缓存机制

[复制链接]
字体大小: 正常 放大

326

主题

32

听众

1万

积分

  • TA的每日心情
    慵懒
    2020-7-12 09:52
  • 签到天数: 116 天

    [LV.6]常住居民II

    管理员

    群组2018教师培训(呼和浩

    群组2017-05-04 量化投资实

    群组2017“草原杯”夏令营

    群组2018美赛冲刺培训

    群组2017 田老师国赛冲刺课

    跳转到指定楼层
    1#
    发表于 2020-6-16 10:34 |只看该作者 |正序浏览
    |招呼Ta 关注Ta
    一、id,is,==! S2 ~0 `' y) z  ?  ~' g) X
    Python中一切皆对象。对象包含三个要素,id、type、value。% j) _* L4 ^* q/ y% P

    2 n9 p8 \5 p$ Q! a2 a* b8 Sid 是对象的内存地址。每当我们创建一个对象的时候都会在内存中开辟一块空间,将这个对象的数据临时存放到内存中,id就是这个空间的唯一标号,就好比身份证号。
    , @8 j) D' i0 i% p4 r3 @) n+ Y9 p1 h5 e" H4 @0 `
    type 是对象的数据类型。包括 int(包括long)、float、string、list、tuple、dict、bool和NoneType 等。
    : g' K0 G) I5 j8 D) e0 Z4 M) K9 a, E# x6 n* [
    value 是对象指向的内存地址中存放的具体的值。
    0 s) Q* g9 s/ d1 x. a4 q  R; u( K7 ~" e% c9 y. K; ~
    因为在对象具有这些要素,所以我们用 is 和 == 两个表达式来判断两个对象是否”相等“9 f7 m+ m3 B, V
    1 K& _' }9 }' S" ]
    is 用于比较两个对象的地址(也就是 id)是否相同,而 == 用于比较两个对象引用的值是否相同, J1 t/ f) I. j  A$ ?, L

    : s3 [7 E  x( H3 x
    ' X$ R9 P" C2 N6 Q# w我们也可以用身份证来理解:每个人都相当于一个对象,而身份证号(id)就唯一标识了世界上的每一个人;可能会存在姓名(value)相同(譬如两个人都叫阿玮),而身份证号不同的两个人。所以说如果内存地址相同,那么值肯定相同;但是如果值相同,内存地址不一定相同。- {- p. m. W( R

    % f3 V" q- @8 M! V$ ]5 p, {二、代码块' s2 n8 J! U- U
    Python程序是由代码块构造的。块是一个 Python 程序的文本,他是作为一个单元执行的
    2 V$ [" T7 i, l7 D3 M$ `
    & d1 X8 u$ Q8 n! E! {+ B代码块:一个模块,一个函数,一个类,一个文件等都是一个代码块& q' P  U" {3 m- O% |

    $ ]! j2 q4 ?/ [9 @- }8 W7 O而作为交互方式输入的每个命令都是一个代码块(如在 iPython)环境中,如:
    " X  P) n: E1 v0 @) R. L# K% M$ l! r8 a, z) o

    : Q9 ^7 e# @  K" a. u1 H/ N而对于同一个文件中的两个函数,也属于两个分别的代码块:
    3 {" O+ v, N) Z, p6 d( }# ?8 B$ f# Q9 R: I, I

    * A7 Q; m* @) g代码块的缓存机制
    7 K) L1 g/ E! k  L前提条件: 同一代码块
    , H8 P( M6 n+ t- x  K5 I( f8 w6 A
    ; T8 v: f7 n' c机制内容: Python在执行同一个代码块的初始化对象的命令时,会检查是否其值是否已经存在,如果存在,会将其重用。换句话说:执行同一个代码块时,遇到初始化对象的命令时,他会将初始化的这个变量与值存储在一个字典中,在遇到新的变量时,会先在字典中查询记录,如果有同样的记录那么它会重复使用这个字典中的之前的这个值。如下面的例子中,文件执行时(同一个代码块)会把 i1、i2 两个变量指向同一个对象,满足缓存机制则他们在内存中只存在一个,即:id 相同。5 y+ Y) k; c1 P0 ~' T

    6 v2 j( X+ O. Y8 w/ h% J) n0 p" c

    : f, ~- [9 b+ L6 ~6 A4 S& R6 g6 r0 F) d2 a5 z
    上面两张图分别为 Pycharm 中和 iPython 中对同一段代码的执行结果。可以看到在 Pycharm 中,代码以一个文件的形式来执行,i1 和 i2 指向了同一个对象;而在 iPython 中,i1 和 i2 是处于不同代码块中的,所以它们两个并不指向同一个对象
    . L3 ?; k  M7 K. p% Y
    4 y& n2 Y* K4 e+ [8 ~适用对象: int(float),str,bool1 w! _# g3 Z" f2 A, y- p' o# V7 F& \
    2 ^2 v( f$ _' |" i) O
    对象的具体细则:
    % c4 u) ^: }0 I- a3 ?1 p9 c8 Y2 S0 y! Z/ k
    int(float):任何数字在同一代码块下都会复用2 Z4 s' d1 A# `8 U+ j9 q
    bool:True和False在字典中会以1,0方式存在,并且复用" \, }+ i5 r$ K  ^
    str:几乎所有的字符串都会符合缓存机制$ i7 I/ Y5 s" }; N/ I; z5 z( y
    非乘法得到的字符串都满足代码块的缓存机制! p7 U; e$ s4 u1 F
    乘法得到的字符串
    / L/ `' t% V/ o2 `- d乘数为1时,任何字符串满足代码块的缓存机制" ]( J' L: A! N2 r+ L- Z  m8 @! M
    乘数>=2时:仅含大小写字母,数字,下划线,总长度<=20,满足代码块的缓存机制
    + n* D4 z* T) c0 _优点: 能够提高一些字符串,整数处理人物在时间和空间上的性能;需要值相同的字符串,整数的时候,直接从‘字典’中取出复用,避免频繁的创建和销毁,提升效率,节约内存8 S+ ]* v) k2 N( d
    - J- H8 [6 t. b9 }* T% U5 c
    # O5 h7 T7 f1 k7 `+ t
    # T. [6 b4 l0 e6 w* l: T4 _1 @
    三、小数据池
    4 x( h* \0 i6 Q前提条件: 不同代码块内。# a$ k& w: I) C3 j. I

    7 x& H$ F  i9 y% n% X适用的对象: int bool str8 A- d" _( j6 i1 h
    7 S, i# U3 ^2 W. d1 J' f1 T
    具体细则:! O% ~4 ?$ O' \0 o" q
    9 \4 |+ f* s& r! q. c2 {0 g, J1 e  B$ b
    int(float):-5~256
    : B' q2 M  o6 b4 |3 [bool:True和False在字典中会以1,0方式存在,并且复用: v; j  }  ^* x3 d& o7 p
    str:满足规则的字符串$ X. r8 O9 Y. }: |4 j
    字符串的长度为0或者1,默认都采用了驻留机制(小数据池)
    * m  O" d$ I1 }9 M5 d4 Q
    3 C4 C( c( L5 i" @5 M字符串的长度>1,且只含有大小写字母,数字,下划线时,才会默认驻留
    / f. _% Y0 ?( d
    ( B7 P; G+ ]# X' J! v, I: }用乘法得到的字符串
    + r4 J' A4 R3 @- W' L1 H' g+ L$ h, V4 w乘数为1时,仅含大小写字母,数字,下划线;其他字符长度<=1,默认驻留. H- w' R' @. y6 b" k- F! {, C: N

      E+ \$ d( L4 S: X5 H$ S8 u2 N乘数>=2时:仅含大小写字母,数字,下划线,总长度<=20,满足代码块的缓存机制# y+ ~& F8 \7 t( c; e) X

    ( i2 q5 e: O0 C( A7 _" W7 R
    " C1 _7 C# B0 m, ]8 t. S8 b+ L! g/ }$ I* R! m3 F5 \5 A( a
    四、总结
    5 ?: I1 _6 R' T! j判断两个对象是否是同一个用 is,判断两个对象的值是否相等用 ==4 }# Y5 b& K, D2 h3 f
    同一个代码块下适用一个缓存机制;不同代码块下适用另一个缓存机制(小数据池)
    # g6 ~; ~( o4 f/ T$ Q0 A————————————————  R9 v7 A$ g# _8 N8 T! P7 T
    版权声明:本文为CSDN博主「阿玮d博客」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。' A9 k: v  j4 n6 u
    原文链接:https://blog.csdn.net/weixin_42511320/article/details/105650842
    , N( R4 A0 f. L' d3 _- w" }9 t$ M, W

    ' ]1 q0 n& i9 i# e
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2026-4-24 22:17 , Processed in 0.436254 second(s), 52 queries .

    回顶部