QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 4040|回复: 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,==/ ~% W- `( [- h  B2 C
    Python中一切皆对象。对象包含三个要素,id、type、value。
    * f  C9 |( `( B- Q2 ^# N; U) l: P) j: {) ~  W) q
    id 是对象的内存地址。每当我们创建一个对象的时候都会在内存中开辟一块空间,将这个对象的数据临时存放到内存中,id就是这个空间的唯一标号,就好比身份证号。+ n9 S8 ?4 K3 _, O. O

    : _, Z2 h% g. U) U; N' i7 |) rtype 是对象的数据类型。包括 int(包括long)、float、string、list、tuple、dict、bool和NoneType 等。
    . ?" g, w4 o' V7 @* z( w" g0 f. r
    8 p! E# X& [( [$ c) g( L* S4 B9 D9 qvalue 是对象指向的内存地址中存放的具体的值。" S: s5 i) g: e. x5 T( e' k) ~5 C" b

    1 }/ S$ j0 D! o9 t$ w) E因为在对象具有这些要素,所以我们用 is 和 == 两个表达式来判断两个对象是否”相等“
    9 l+ V" n- v6 d  D& `9 X$ Y% S1 k8 S1 K( p
    is 用于比较两个对象的地址(也就是 id)是否相同,而 == 用于比较两个对象引用的值是否相同
    ; J# }% F: q: ]" W- U2 g0 \; C( ?) B& @6 [' q, X; v
    0 A: x9 `" j9 k# j  B, q; ]) B
    我们也可以用身份证来理解:每个人都相当于一个对象,而身份证号(id)就唯一标识了世界上的每一个人;可能会存在姓名(value)相同(譬如两个人都叫阿玮),而身份证号不同的两个人。所以说如果内存地址相同,那么值肯定相同;但是如果值相同,内存地址不一定相同。" ^1 M6 S, @, t' y  ~% n7 D
    9 c: W5 P5 V5 v9 Z% G- Q0 ]
    二、代码块
    ) Z2 a8 |6 l' @: Z- HPython程序是由代码块构造的。块是一个 Python 程序的文本,他是作为一个单元执行的( o7 Q) D, G$ J/ d2 _* |5 C6 e
    / r% Z) N# l5 ~4 E! C% F
    代码块:一个模块,一个函数,一个类,一个文件等都是一个代码块
    2 F) z3 u  W. \* _
    5 ]. g& K' U/ ~4 z而作为交互方式输入的每个命令都是一个代码块(如在 iPython)环境中,如:
    0 m' S( o- G7 d$ G/ b% N5 q+ r1 @- Z4 r- b3 [7 ~
    4 {( F9 l3 M6 P: R! A
    而对于同一个文件中的两个函数,也属于两个分别的代码块:
    8 p; q% d9 I  ?. X) M0 _! j
    6 s6 C3 ]2 Y$ _% o! E% F8 w1 ~- m$ @, a7 M  K3 }6 ^
    代码块的缓存机制/ ?3 c" j& j5 K. ?
    前提条件: 同一代码块  _8 G6 v2 b" B& ~+ H

    : D* N. @! x: _/ q' P6 D机制内容: Python在执行同一个代码块的初始化对象的命令时,会检查是否其值是否已经存在,如果存在,会将其重用。换句话说:执行同一个代码块时,遇到初始化对象的命令时,他会将初始化的这个变量与值存储在一个字典中,在遇到新的变量时,会先在字典中查询记录,如果有同样的记录那么它会重复使用这个字典中的之前的这个值。如下面的例子中,文件执行时(同一个代码块)会把 i1、i2 两个变量指向同一个对象,满足缓存机制则他们在内存中只存在一个,即:id 相同。
    - W1 r' ?) ^/ R2 n. b3 O: ~
    ! ]& H: |9 }# |2 Z% d/ A. B: A& q, F0 @" q# j: v$ q

    7 N3 H/ U2 u- }% x: \9 g- l3 r7 P7 J( R5 J, Z/ g9 Y6 V
    上面两张图分别为 Pycharm 中和 iPython 中对同一段代码的执行结果。可以看到在 Pycharm 中,代码以一个文件的形式来执行,i1 和 i2 指向了同一个对象;而在 iPython 中,i1 和 i2 是处于不同代码块中的,所以它们两个并不指向同一个对象( U& B  A: r. o4 q, x! t2 H

    : y, U) Q' |0 t. H3 P适用对象: int(float),str,bool' c2 @1 K+ f$ A# Q% \; m
    % R! ?' s; N2 S  R
    对象的具体细则:
    " a, p5 _: i* O" n1 y: m
    7 }, A$ S9 D4 T" ^6 j  x! Uint(float):任何数字在同一代码块下都会复用
    % S$ F. }4 k) k! ]& F) e  u1 Ibool:True和False在字典中会以1,0方式存在,并且复用
    ; v+ U6 |. T. Q$ F! Mstr:几乎所有的字符串都会符合缓存机制7 A  P4 q' |1 f- l2 Z3 q
    非乘法得到的字符串都满足代码块的缓存机制
    3 y, `) _' \- _乘法得到的字符串
    - A% j4 {0 V6 N1 S. p6 t, U; ]乘数为1时,任何字符串满足代码块的缓存机制
    1 D( {! H- T6 x乘数>=2时:仅含大小写字母,数字,下划线,总长度<=20,满足代码块的缓存机制; _1 q* U0 S; Z! e
    优点: 能够提高一些字符串,整数处理人物在时间和空间上的性能;需要值相同的字符串,整数的时候,直接从‘字典’中取出复用,避免频繁的创建和销毁,提升效率,节约内存. `( v2 t3 M1 D- p+ Q
    . W; p. O) D9 H

    / y/ c7 a  w! k0 J' z
    & ^" r0 V6 I7 c) c! y1 P三、小数据池1 v+ F3 n* O- Y" R/ G' w( z
    前提条件: 不同代码块内。" ^+ U; B9 c2 N( z

    ) c$ z  K" G& m0 A8 U( N适用的对象: int bool str
    ( U8 _4 ^' _* n; X3 t
    8 t2 r( j0 _# [; g3 U  R5 ^( \: W具体细则:0 Z/ A! v4 u, Y
    & I' e. e: |% @" B/ x. V
    int(float):-5~256
    & X( ^. o0 j8 ybool:True和False在字典中会以1,0方式存在,并且复用7 \" T2 F: q; N& A* H2 [8 o3 [
    str:满足规则的字符串/ ?5 n5 r5 l% E" ^+ q$ `+ V9 G
    字符串的长度为0或者1,默认都采用了驻留机制(小数据池)5 J8 N# y6 z' Q+ u% \% w

    : T( c9 ~& _9 l" w5 F: d5 [字符串的长度>1,且只含有大小写字母,数字,下划线时,才会默认驻留
    , P. d/ I! [. C( ?5 n# ]
    7 H" O  H- w) f+ Y( \6 c% X用乘法得到的字符串
    8 {1 j6 m. q# M9 c( `乘数为1时,仅含大小写字母,数字,下划线;其他字符长度<=1,默认驻留, w5 u1 K  ?# b) J; [0 u6 i

      l+ M5 J2 J' J乘数>=2时:仅含大小写字母,数字,下划线,总长度<=20,满足代码块的缓存机制
    / [  ]/ v! x/ q* g  v$ Y/ U  {0 L- `) ]

    7 K$ a1 A" f$ a) V; J- f, x
    ( \9 N& H# ~& c) P0 g' p四、总结
    2 s9 Q' r, |8 [: ~判断两个对象是否是同一个用 is,判断两个对象的值是否相等用 ==
    2 u1 [, ~# y4 Z" B' f1 p* @同一个代码块下适用一个缓存机制;不同代码块下适用另一个缓存机制(小数据池); t7 A; @4 _3 S# _, f9 ?1 E+ G- u3 }
    ————————————————/ z* a+ r* ~- N) P0 Z  X+ w: p
    版权声明:本文为CSDN博主「阿玮d博客」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。0 _1 w' S1 E1 a9 s
    原文链接:https://blog.csdn.net/weixin_42511320/article/details/105650842
    9 e4 p. w+ y1 m! d& O! e' T
    3 e8 D0 r  L+ s* m% W; Z; I, }& x  z6 ]. T4 f% i" f% ?0 a+ I9 o
    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 23:28 , Processed in 0.325801 second(s), 56 queries .

    回顶部