QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 4036|回复: 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,==
    # o& v6 L  T" |$ y! x6 ?" k' HPython中一切皆对象。对象包含三个要素,id、type、value。
    , z, k% K4 s3 T  _/ F% S1 J
    8 f3 p$ i. a% ~3 x& ^id 是对象的内存地址。每当我们创建一个对象的时候都会在内存中开辟一块空间,将这个对象的数据临时存放到内存中,id就是这个空间的唯一标号,就好比身份证号。
    - u" H% W  R) ?2 o: R
    / x- o9 t, x5 O" e! Otype 是对象的数据类型。包括 int(包括long)、float、string、list、tuple、dict、bool和NoneType 等。6 b9 Z) ^+ G- g. X' T% O
    ! p' M( N- U% P8 y- a, P( v/ K& ^# {
    value 是对象指向的内存地址中存放的具体的值。3 H, I" {+ u( K! r( h
    9 B, e; `5 U; K, a5 F4 k
    因为在对象具有这些要素,所以我们用 is 和 == 两个表达式来判断两个对象是否”相等“: _2 }$ ^7 f: y4 t6 S' Q9 R/ E3 |" }

    1 d- Q$ e0 i2 u- dis 用于比较两个对象的地址(也就是 id)是否相同,而 == 用于比较两个对象引用的值是否相同
    4 U* h& L" b' f$ C: T  t; H! N6 I' q8 F, `) i" e. [  @

    5 F7 ^5 a) b9 L; U5 D& E我们也可以用身份证来理解:每个人都相当于一个对象,而身份证号(id)就唯一标识了世界上的每一个人;可能会存在姓名(value)相同(譬如两个人都叫阿玮),而身份证号不同的两个人。所以说如果内存地址相同,那么值肯定相同;但是如果值相同,内存地址不一定相同。/ m- c  E% c; F, n
    ( _. m5 r' h7 ^- ^( p6 y: U
    二、代码块
    + U  v( }6 g  l( P7 GPython程序是由代码块构造的。块是一个 Python 程序的文本,他是作为一个单元执行的
    ' n8 p/ q1 e8 \
    : H( \3 F0 E2 y# {! n8 V0 o代码块:一个模块,一个函数,一个类,一个文件等都是一个代码块
    9 c) U$ Z' p; w2 D$ u  r% T3 K: n# v, O. X7 h' R
    而作为交互方式输入的每个命令都是一个代码块(如在 iPython)环境中,如:7 ~! F& i4 G3 o$ E$ O
    6 @7 h0 ^9 ?: Z% i
    0 q* p- a% X" S+ X' D5 U
    而对于同一个文件中的两个函数,也属于两个分别的代码块:. P% W( s% K4 t
    $ @, H- R, s# e; G& C

    / E4 [# D& A/ x5 F* a代码块的缓存机制
    . U  E$ M* Q" ^前提条件: 同一代码块; D# Y" k5 Y+ }5 o- _. v- ^" [/ ^/ x

    ' w  L3 V; b, j5 T2 _( Q; U; h# g机制内容: Python在执行同一个代码块的初始化对象的命令时,会检查是否其值是否已经存在,如果存在,会将其重用。换句话说:执行同一个代码块时,遇到初始化对象的命令时,他会将初始化的这个变量与值存储在一个字典中,在遇到新的变量时,会先在字典中查询记录,如果有同样的记录那么它会重复使用这个字典中的之前的这个值。如下面的例子中,文件执行时(同一个代码块)会把 i1、i2 两个变量指向同一个对象,满足缓存机制则他们在内存中只存在一个,即:id 相同。
    & x% H9 a5 l8 K" x0 o* b- a; c" ^1 Y. E: P8 c7 C# S" P- L" `, I9 S

    ! w4 ]1 R7 w- ~) [2 i, F- b5 s# W$ \; k
    # R0 V- p1 N& q
    上面两张图分别为 Pycharm 中和 iPython 中对同一段代码的执行结果。可以看到在 Pycharm 中,代码以一个文件的形式来执行,i1 和 i2 指向了同一个对象;而在 iPython 中,i1 和 i2 是处于不同代码块中的,所以它们两个并不指向同一个对象
    / r! R6 h8 `" a+ L* D, v( n; s4 h+ _7 O5 V
    适用对象: int(float),str,bool4 e5 P) S6 `) ?
    1 v' ]: \2 {2 X+ o4 H
    对象的具体细则:
    ) u0 h" j0 R& e$ k+ E. \
    * m5 U" j9 g2 W3 x! X* dint(float):任何数字在同一代码块下都会复用& x! t. A" M! i0 h/ x
    bool:True和False在字典中会以1,0方式存在,并且复用
    ) M& R* M6 J8 Ystr:几乎所有的字符串都会符合缓存机制3 P2 _, W6 F) B* c' m# \; v; H
    非乘法得到的字符串都满足代码块的缓存机制1 q4 L, `) L& M; w4 P5 L
    乘法得到的字符串" ]  [( ?+ T9 c/ A" @# g
    乘数为1时,任何字符串满足代码块的缓存机制( F" `' }7 w# W9 B: C' b9 y
    乘数>=2时:仅含大小写字母,数字,下划线,总长度<=20,满足代码块的缓存机制0 V# F0 w) [: b
    优点: 能够提高一些字符串,整数处理人物在时间和空间上的性能;需要值相同的字符串,整数的时候,直接从‘字典’中取出复用,避免频繁的创建和销毁,提升效率,节约内存
    : n( @" [' J4 e8 ?: _* x, [# A& m/ h4 Q% L( _, I
    $ l% g) W# M) V2 [

    ; P# A+ m! Y8 I! ?5 ?三、小数据池
    9 b, c' l/ {/ }前提条件: 不同代码块内。
    4 }' P, ^: v) w( p+ A) b6 o$ p
    3 C2 N: n7 \& p3 b( K7 v, G适用的对象: int bool str
    6 r, \. w, W) v$ v
    ( }% U4 K$ `5 `. |9 ?0 P# ^4 [/ L7 }具体细则:
    $ `6 b3 E& A. z6 I& L) k# }9 R" B& U) L/ T) s5 S/ s+ N3 u; N. [% _
    int(float):-5~256$ L- P. G' }& ?8 t  T) j& f
    bool:True和False在字典中会以1,0方式存在,并且复用/ o  a* f  k7 B4 q. ^) ~; O
    str:满足规则的字符串7 `* S! N& H2 ?! v0 }! ^
    字符串的长度为0或者1,默认都采用了驻留机制(小数据池)
    + {! Y# [0 e6 d7 t9 [) }4 y4 o0 n0 n
    字符串的长度>1,且只含有大小写字母,数字,下划线时,才会默认驻留
    $ R' H) E4 x+ F: D
    6 `* ~% q8 K4 W3 i用乘法得到的字符串, y( t1 z- Q4 a* w6 N4 D
    乘数为1时,仅含大小写字母,数字,下划线;其他字符长度<=1,默认驻留8 K1 |. l! {; E/ h

    1 `# p9 I" Z0 I. k9 j* L乘数>=2时:仅含大小写字母,数字,下划线,总长度<=20,满足代码块的缓存机制) P8 u; a, T6 W6 v" p% d

    % [; q4 B/ d: L2 ^- i
    : E+ F4 |" J" k, y2 F; p; h# w* Y
    6 [' q! [- e0 U6 e7 ?& H; K四、总结( V! Y2 }* |4 s" b' J. Q
    判断两个对象是否是同一个用 is,判断两个对象的值是否相等用 ==
      [7 M; O. N  Q同一个代码块下适用一个缓存机制;不同代码块下适用另一个缓存机制(小数据池)
    4 t9 ?' Z+ Z' d, H' ?) q. Z————————————————. C: e' {. O6 M+ Q
    版权声明:本文为CSDN博主「阿玮d博客」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
      E7 [1 |; K' b* o原文链接:https://blog.csdn.net/weixin_42511320/article/details/105650842
    & R3 w( P# w& g% ^' t: l6 z* [
    + L) m4 T+ ~/ `* b9 \
    5 e4 S- P* N1 @3 s
    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-23 07:53 , Processed in 0.354834 second(s), 50 queries .

    回顶部