QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 4038|回复: 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,==  d2 Q6 [$ p( F. E" _3 L
    Python中一切皆对象。对象包含三个要素,id、type、value。( Z2 G8 x2 e( w6 |
      O) U8 w; M0 `$ X
    id 是对象的内存地址。每当我们创建一个对象的时候都会在内存中开辟一块空间,将这个对象的数据临时存放到内存中,id就是这个空间的唯一标号,就好比身份证号。. s# R. x9 k2 e+ H
    ( c8 p4 T" E1 _% }$ P; W6 {8 j+ U
    type 是对象的数据类型。包括 int(包括long)、float、string、list、tuple、dict、bool和NoneType 等。
    * ^" @0 k3 W3 T  S& G/ }* P0 x: k% B' F- R! c$ o5 |" V
    value 是对象指向的内存地址中存放的具体的值。" O" W7 h8 H  I9 E- _
    0 `* o& T# @# H, {+ [) x* C
    因为在对象具有这些要素,所以我们用 is 和 == 两个表达式来判断两个对象是否”相等“
    ) r8 `7 P4 n8 _1 e8 o; g9 l8 u  j6 H+ k% |3 O7 t7 |0 {
    is 用于比较两个对象的地址(也就是 id)是否相同,而 == 用于比较两个对象引用的值是否相同
    4 S2 l) t! u- K4 h! i# ]3 `% c% y1 S% }2 x! v, z3 R

    3 F2 W2 u6 j5 |+ @! }/ ~6 }我们也可以用身份证来理解:每个人都相当于一个对象,而身份证号(id)就唯一标识了世界上的每一个人;可能会存在姓名(value)相同(譬如两个人都叫阿玮),而身份证号不同的两个人。所以说如果内存地址相同,那么值肯定相同;但是如果值相同,内存地址不一定相同。# j. i9 Y9 X) m" d6 R
    9 O; e+ m9 A. \; V0 v5 S' k! T5 B
    二、代码块
    0 i, o  B# {# e6 b' Z7 d7 U  d0 FPython程序是由代码块构造的。块是一个 Python 程序的文本,他是作为一个单元执行的0 u% x  ?: }: j  P: X

    % j' @! ?3 [! y1 b( F0 p代码块:一个模块,一个函数,一个类,一个文件等都是一个代码块
    2 Z, M3 i. Y* Z! \7 E8 x  t
    3 X! u# Y* w1 Q1 m而作为交互方式输入的每个命令都是一个代码块(如在 iPython)环境中,如:$ f: w3 E0 _$ G3 w" g/ q8 i

    $ G3 f9 ~8 U8 x! I' E1 S% D8 m# j- U) F9 \5 J
    而对于同一个文件中的两个函数,也属于两个分别的代码块:) h% L* c  R0 M" x# f' L
    + _) r  r1 {; d* X) Z
    # T6 q: f2 p, c" w/ A- R3 C* _
    代码块的缓存机制2 A0 w( |+ E  x6 _9 b. L3 G& H
    前提条件: 同一代码块
    7 f* }/ `* L$ {5 v' E4 S* O! B4 ]; J* A% k: ]# H/ C
    机制内容: Python在执行同一个代码块的初始化对象的命令时,会检查是否其值是否已经存在,如果存在,会将其重用。换句话说:执行同一个代码块时,遇到初始化对象的命令时,他会将初始化的这个变量与值存储在一个字典中,在遇到新的变量时,会先在字典中查询记录,如果有同样的记录那么它会重复使用这个字典中的之前的这个值。如下面的例子中,文件执行时(同一个代码块)会把 i1、i2 两个变量指向同一个对象,满足缓存机制则他们在内存中只存在一个,即:id 相同。
    # L+ ~1 [/ }2 w4 k4 o8 n+ }9 r* s* n% l$ R. Q) ~
    $ X5 z! Q* G7 S: n- O  E& h
    . U/ E; s0 x, Z" Y
    + f$ w9 G5 E, [; \& _- _; i
    上面两张图分别为 Pycharm 中和 iPython 中对同一段代码的执行结果。可以看到在 Pycharm 中,代码以一个文件的形式来执行,i1 和 i2 指向了同一个对象;而在 iPython 中,i1 和 i2 是处于不同代码块中的,所以它们两个并不指向同一个对象3 G+ ^; U) P* y. A
    # d2 R2 _8 \# j  D3 e; ]
    适用对象: int(float),str,bool
    ( J& b- ^, a3 m, V% t7 y: Z' Q, y: f5 w7 _1 P
    对象的具体细则:
    ( }0 E! K4 `5 W# ~- ?4 d
    ! S5 H# o; Y5 t% D$ B1 x; u) Xint(float):任何数字在同一代码块下都会复用* q+ D) B8 z0 p6 ]  A1 s7 W# b- {
    bool:True和False在字典中会以1,0方式存在,并且复用
    0 C6 A; l+ y4 V2 z2 w( istr:几乎所有的字符串都会符合缓存机制- F5 a$ \9 I1 w
    非乘法得到的字符串都满足代码块的缓存机制
    * v1 v* Y$ J3 F9 x- M$ L: a, T. ~乘法得到的字符串6 l" ^2 J. i. K! Z& Y
    乘数为1时,任何字符串满足代码块的缓存机制' v' }& J3 Y% i3 X$ e- `4 L
    乘数>=2时:仅含大小写字母,数字,下划线,总长度<=20,满足代码块的缓存机制
    . z2 N9 ?! h& f: Z优点: 能够提高一些字符串,整数处理人物在时间和空间上的性能;需要值相同的字符串,整数的时候,直接从‘字典’中取出复用,避免频繁的创建和销毁,提升效率,节约内存
    + g* U. X9 f( r( \  U
    # {; M+ v( d( p$ h9 _7 G
    ) I4 L. _( ]' ?" x5 I& T. i. R- C3 ^7 O
    三、小数据池, |6 G2 u1 d# Z( c8 C/ U* W
    前提条件: 不同代码块内。
    + T  w# F; D( {2 w) L4 Z% W* V1 o1 a$ q8 j0 O( l7 q
    适用的对象: int bool str  y2 E3 Y" |* S6 E, l
    # N- C( Z% k; z8 `
    具体细则:
    ; b% m2 n% p* W5 D/ V, v5 f: l9 t8 n* P
    int(float):-5~256
    ; z3 f* O) F! [0 Mbool:True和False在字典中会以1,0方式存在,并且复用3 c- }1 @% e  _! ]! [- h
    str:满足规则的字符串
    $ c' @: m% @. a# K/ r5 C字符串的长度为0或者1,默认都采用了驻留机制(小数据池)- S$ w9 T$ Q* K+ f3 w7 S) x

    % `& A% p/ r. R. s8 D字符串的长度>1,且只含有大小写字母,数字,下划线时,才会默认驻留) g8 C$ |8 c8 f/ j$ v

    % d* Z$ c$ u2 b" o3 N( U用乘法得到的字符串' G4 E, {2 }8 D+ X* o
    乘数为1时,仅含大小写字母,数字,下划线;其他字符长度<=1,默认驻留: d1 r1 x. v" H+ K- w5 n, W8 N3 y

    ' @  S( }% k/ n' G! V& m: z乘数>=2时:仅含大小写字母,数字,下划线,总长度<=20,满足代码块的缓存机制6 |; ^0 k, G, m. g4 C0 C( p
    0 l/ H2 [9 c0 ]: ~

    + ?* E/ Y- y5 |+ q; ^- P8 J9 ?) i6 S7 V3 v8 f6 H
    四、总结
    ( D# t4 a( y% M1 n判断两个对象是否是同一个用 is,判断两个对象的值是否相等用 ==8 m6 r0 A& R1 _
    同一个代码块下适用一个缓存机制;不同代码块下适用另一个缓存机制(小数据池)' g" C" M3 k3 s  S
    ————————————————& h1 Q4 S$ d- [
    版权声明:本文为CSDN博主「阿玮d博客」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    7 g+ ]7 I! i! j9 A1 X% K+ J原文链接:https://blog.csdn.net/weixin_42511320/article/details/105650842* @8 e6 ]$ q% e

    * L5 A6 ~0 n: R) b# Y8 L! m
    ) Y% M( Q) \) o; A2 A
    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 09:45 , Processed in 0.422862 second(s), 51 queries .

    回顶部