QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 4070|回复: 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,==* C- n! p# a  Q# H$ e
    Python中一切皆对象。对象包含三个要素,id、type、value。& ~7 x4 k" m) n2 _' e. w. t6 H# L
    2 h7 M# J2 B/ ^' x( g( k; p4 G
    id 是对象的内存地址。每当我们创建一个对象的时候都会在内存中开辟一块空间,将这个对象的数据临时存放到内存中,id就是这个空间的唯一标号,就好比身份证号。! D& o- X/ \4 `6 ?0 n
    0 x4 m* v4 e+ M& F3 j9 z* |
    type 是对象的数据类型。包括 int(包括long)、float、string、list、tuple、dict、bool和NoneType 等。
    8 A/ \: u! ^1 Y! `& |
    $ ~( J* s  Q+ L- l0 |5 G3 Avalue 是对象指向的内存地址中存放的具体的值。
    ! b5 ]$ E/ |$ a( G
    9 n# Y* y% ~: k6 P2 u2 K8 }因为在对象具有这些要素,所以我们用 is 和 == 两个表达式来判断两个对象是否”相等“
    2 X0 c  m, w% Y( o; l( L1 o, E. T2 g, h+ r3 x) S' ?6 A2 S" L: D
    is 用于比较两个对象的地址(也就是 id)是否相同,而 == 用于比较两个对象引用的值是否相同( d3 M, F  U! M  e( D* m
    ( s. l; F5 _: Q

    / p$ \3 }3 C7 e* Q1 X我们也可以用身份证来理解:每个人都相当于一个对象,而身份证号(id)就唯一标识了世界上的每一个人;可能会存在姓名(value)相同(譬如两个人都叫阿玮),而身份证号不同的两个人。所以说如果内存地址相同,那么值肯定相同;但是如果值相同,内存地址不一定相同。
    ' }# A6 G2 q4 w- Z9 e! H4 O) q+ d7 a! T3 T0 \$ v
    二、代码块* [4 E" o! h! H) \* w& k: c; {
    Python程序是由代码块构造的。块是一个 Python 程序的文本,他是作为一个单元执行的
    0 J; t, \$ m. K
    8 }( G- j/ f9 l& V代码块:一个模块,一个函数,一个类,一个文件等都是一个代码块. ^( c) M: v7 f7 a. o5 a" X; w" O

    5 c/ W( n) g# d& K9 t而作为交互方式输入的每个命令都是一个代码块(如在 iPython)环境中,如:
    # `* I$ L  a* q: q3 d4 O
    ; z* d) @1 C9 b  J0 O1 {* c6 |4 F- R3 n
    而对于同一个文件中的两个函数,也属于两个分别的代码块:7 @0 T7 m. z+ N' Y% z- Y
    ' v3 Q% o) f; y7 h2 }/ S# y9 j. ]

    ) p+ {* K% U) K) X代码块的缓存机制
    : X& H- y6 H7 U6 f# J前提条件: 同一代码块0 f! O+ B9 p6 P  k' x
    5 y6 g% S0 c* }5 d' d/ V& f1 s% W8 \
    机制内容: Python在执行同一个代码块的初始化对象的命令时,会检查是否其值是否已经存在,如果存在,会将其重用。换句话说:执行同一个代码块时,遇到初始化对象的命令时,他会将初始化的这个变量与值存储在一个字典中,在遇到新的变量时,会先在字典中查询记录,如果有同样的记录那么它会重复使用这个字典中的之前的这个值。如下面的例子中,文件执行时(同一个代码块)会把 i1、i2 两个变量指向同一个对象,满足缓存机制则他们在内存中只存在一个,即:id 相同。
    * A1 C& }) s; M& v/ I+ V3 W! [
    + U  f4 C+ w) E
    , u7 z$ D- s& w, ]6 {' \& Y$ S( A+ n  k2 ?
    6 A3 y1 W+ X: \) }- C( F0 U
    上面两张图分别为 Pycharm 中和 iPython 中对同一段代码的执行结果。可以看到在 Pycharm 中,代码以一个文件的形式来执行,i1 和 i2 指向了同一个对象;而在 iPython 中,i1 和 i2 是处于不同代码块中的,所以它们两个并不指向同一个对象3 F  D# J& p! K* Z1 r

    & ]) R# k: _0 k# F适用对象: int(float),str,bool
    $ D, @  I. p, D2 ^/ \
    $ s3 l+ w* e- h3 G: d. W对象的具体细则:
    + K. J0 j7 e' @$ K
    7 j" f( p1 x9 A# [& a4 S4 h- K9 Oint(float):任何数字在同一代码块下都会复用! J7 Z: l6 W& o& D0 X
    bool:True和False在字典中会以1,0方式存在,并且复用. x# ]! J, Q6 [+ k. G* Q
    str:几乎所有的字符串都会符合缓存机制2 h9 p9 x) a; x& @! o6 V
    非乘法得到的字符串都满足代码块的缓存机制5 W5 {! K. ^7 x5 |1 k9 P1 u7 i
    乘法得到的字符串" w" s3 @2 M0 j4 O1 E( W4 U
    乘数为1时,任何字符串满足代码块的缓存机制
    * y' z0 A6 l; U乘数>=2时:仅含大小写字母,数字,下划线,总长度<=20,满足代码块的缓存机制
    $ j& v. O' X) |  @' m# T  d优点: 能够提高一些字符串,整数处理人物在时间和空间上的性能;需要值相同的字符串,整数的时候,直接从‘字典’中取出复用,避免频繁的创建和销毁,提升效率,节约内存9 X- |* H' m7 W/ p% u, |: g

    ) }/ b( }7 o' |  `- z6 w: ]  X3 t% G9 |2 O6 O" _
    ! A: h7 H2 M8 P9 I5 C# H0 R
    三、小数据池7 U. w/ [( u! u8 E/ \, u1 i) y
    前提条件: 不同代码块内。
    : e5 t- e, H. u6 j% D1 J
    ; ~9 _: s$ G6 t: M适用的对象: int bool str( D6 A  |/ z5 K/ D0 ]
    5 |1 a9 R  f' i, K8 W# @$ O
    具体细则:
    - B% ]7 @  e1 }, s% Z4 `* Z( [. K' M  N$ I/ Y/ D
    int(float):-5~2564 r! N/ z- Z& s* }( j; ?# Q# R
    bool:True和False在字典中会以1,0方式存在,并且复用
    0 [/ o3 X) O7 \: E: |1 |str:满足规则的字符串  t5 _3 `$ D  [; Y8 u9 Z
    字符串的长度为0或者1,默认都采用了驻留机制(小数据池)* ]8 X- O/ N! _1 x: L  C* W
    ' x$ r3 G9 M/ K8 h) {
    字符串的长度>1,且只含有大小写字母,数字,下划线时,才会默认驻留
    3 j0 L* u3 i+ k- A
    ' E' a) v& \; j/ t, f用乘法得到的字符串
    * @( ]: ]/ [. R4 k  ?乘数为1时,仅含大小写字母,数字,下划线;其他字符长度<=1,默认驻留
    & b5 t' ?* i# `. p8 Q9 @, \6 Y* O) M0 A
    乘数>=2时:仅含大小写字母,数字,下划线,总长度<=20,满足代码块的缓存机制* ?$ F( W" U$ A2 w  B
    0 [7 L: B9 E+ K( b
    # Z$ H( Z  f# ~. g
    + r  L: x0 p2 z) G# n+ O- M' \. R4 w
    四、总结
    ) \( p5 i. @' b判断两个对象是否是同一个用 is,判断两个对象的值是否相等用 ==8 H! X8 O8 T) X/ o  {
    同一个代码块下适用一个缓存机制;不同代码块下适用另一个缓存机制(小数据池)7 P- l% E$ R  r4 e# H
    ————————————————
    % U$ x# y4 T: z+ T5 R" p版权声明:本文为CSDN博主「阿玮d博客」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。: {0 `) W# C1 w  R
    原文链接:https://blog.csdn.net/weixin_42511320/article/details/105650842
    : p/ w& m; W8 V+ \  C& h! |% G3 Q

    - F5 J  P+ L: E7 B: r* t+ g% e9 C
    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-6-14 06:24 , Processed in 0.361358 second(s), 51 queries .

    回顶部