QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 4032|回复: 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: X! l. c( X5 y9 E
    Python中一切皆对象。对象包含三个要素,id、type、value。
    " c* \* d) }5 c  a# M  l0 c2 K. O4 d4 O9 n. Q5 z, G7 `
    id 是对象的内存地址。每当我们创建一个对象的时候都会在内存中开辟一块空间,将这个对象的数据临时存放到内存中,id就是这个空间的唯一标号,就好比身份证号。
    7 F& l7 \, f  T7 f( d* b" t+ K3 U- s) T
    type 是对象的数据类型。包括 int(包括long)、float、string、list、tuple、dict、bool和NoneType 等。
    5 v7 y( f" L! Z) _" E3 @& N: c8 W( G* I# x% Z  x$ E$ \
    value 是对象指向的内存地址中存放的具体的值。
    + Z* r8 K" x. h9 _" a' G- l; `) ]& g0 @( g1 {7 p/ q* j
    因为在对象具有这些要素,所以我们用 is 和 == 两个表达式来判断两个对象是否”相等“- d  c5 B+ U% m

    1 g1 O: N4 n8 I: m7 F. ^. Ois 用于比较两个对象的地址(也就是 id)是否相同,而 == 用于比较两个对象引用的值是否相同
    # d4 e/ `  ?' Y& G- I' [, u% P4 `6 i' h0 S) G/ v
    5 G) c' m, d2 T
    我们也可以用身份证来理解:每个人都相当于一个对象,而身份证号(id)就唯一标识了世界上的每一个人;可能会存在姓名(value)相同(譬如两个人都叫阿玮),而身份证号不同的两个人。所以说如果内存地址相同,那么值肯定相同;但是如果值相同,内存地址不一定相同。$ z" Y8 e* ]* y6 Q
    , N& {( i' I' q. ^
    二、代码块
    - m. f/ G; t9 w, z% p# n& h# @+ `% D0 KPython程序是由代码块构造的。块是一个 Python 程序的文本,他是作为一个单元执行的$ ]% o, @/ X9 Y2 i. s. j% e
    # t" _& J. R) E+ M2 _) q6 v
    代码块:一个模块,一个函数,一个类,一个文件等都是一个代码块
    ; A( r8 u+ k( c- F; ]
      r2 F- q# A  D3 G& M而作为交互方式输入的每个命令都是一个代码块(如在 iPython)环境中,如:. Z+ s' d- X9 T

    . z& f( w. b( G+ H+ C% W' ?( [! k! I8 G
    而对于同一个文件中的两个函数,也属于两个分别的代码块:
    9 g7 b1 _8 S5 h( u3 [6 o& [3 {" R0 q* J- d

    6 C$ [/ @( x- T) V" W( m代码块的缓存机制
    # M4 j1 [9 t- r2 v  W+ ?前提条件: 同一代码块
    ) ^: ^; }9 A, n% J5 r& v) w+ G; R, Y! B/ u6 d& @
    机制内容: Python在执行同一个代码块的初始化对象的命令时,会检查是否其值是否已经存在,如果存在,会将其重用。换句话说:执行同一个代码块时,遇到初始化对象的命令时,他会将初始化的这个变量与值存储在一个字典中,在遇到新的变量时,会先在字典中查询记录,如果有同样的记录那么它会重复使用这个字典中的之前的这个值。如下面的例子中,文件执行时(同一个代码块)会把 i1、i2 两个变量指向同一个对象,满足缓存机制则他们在内存中只存在一个,即:id 相同。
    1 w0 i2 e# Z. ~) Y: z6 C* k6 z1 y. u1 t4 q' V. t8 ]5 n
    / `3 I4 W7 ]7 {8 N! Z0 Z

      n' G7 t1 W2 D6 D# g3 P1 n' M
    上面两张图分别为 Pycharm 中和 iPython 中对同一段代码的执行结果。可以看到在 Pycharm 中,代码以一个文件的形式来执行,i1 和 i2 指向了同一个对象;而在 iPython 中,i1 和 i2 是处于不同代码块中的,所以它们两个并不指向同一个对象
    9 C8 B" d6 n6 V+ t1 m  l( H5 l( v% o! I
    适用对象: int(float),str,bool+ Z$ h$ L0 A& ?3 `+ I+ p  J9 V
    . Z# z7 q3 {" v$ [: c( G, J
    对象的具体细则:
    * ^2 [' ?" m2 U( X6 f% y; A9 o6 P* J# h7 R4 _# G9 E" T
    int(float):任何数字在同一代码块下都会复用
    6 i9 Y- z3 F+ g: X# J" O( bbool:True和False在字典中会以1,0方式存在,并且复用- C' F' Z; y( G. C' i
    str:几乎所有的字符串都会符合缓存机制0 Y& V' Y; E' v; Y% ^! }, r
    非乘法得到的字符串都满足代码块的缓存机制* H$ j4 G* |% n3 e! d6 @
    乘法得到的字符串
    " ]+ C% P: t4 `/ H3 P: `% \( v; Z( F乘数为1时,任何字符串满足代码块的缓存机制9 N  Y& \3 b! }- j5 J
    乘数>=2时:仅含大小写字母,数字,下划线,总长度<=20,满足代码块的缓存机制
    2 Z0 P) C( N7 @9 j* }# V优点: 能够提高一些字符串,整数处理人物在时间和空间上的性能;需要值相同的字符串,整数的时候,直接从‘字典’中取出复用,避免频繁的创建和销毁,提升效率,节约内存
    " ]8 G! Z% b* E7 b
    ' `. i" s% q4 w/ A+ M* n" z, z* a3 I5 z9 p) Y( y9 {
    " @8 \- Q5 l# v# l+ z' a" v/ v# W6 Q$ q
    三、小数据池
    ( }+ o2 G* _2 Y* h* z/ X# t3 B- U前提条件: 不同代码块内。
    # r5 o0 h  X- y# a+ ]
    9 R9 c* L6 h5 |/ v; _; }适用的对象: int bool str
    - R/ e6 Q0 }4 K6 H, b( w
    $ ]8 X; @& W0 }# x( j4 `6 w% {具体细则:
    : a0 r! Y# t( Z) C; D* e3 W& _
    / m  A2 @( @' v6 {: Rint(float):-5~2563 M: }$ `1 d' @" I' O$ N& d
    bool:True和False在字典中会以1,0方式存在,并且复用2 r% ~( [, G" z! @$ ^  w
    str:满足规则的字符串
    " d  W6 W' A: F' {* x字符串的长度为0或者1,默认都采用了驻留机制(小数据池)+ c, p+ @3 \& F+ l- K  @6 w2 H
    $ w$ C9 ~* \% U. J# k
    字符串的长度>1,且只含有大小写字母,数字,下划线时,才会默认驻留/ }$ H9 h2 B8 I; V1 J( i

    4 o( b% u0 U$ D+ E用乘法得到的字符串# k4 Y" ]1 o, H( t
    乘数为1时,仅含大小写字母,数字,下划线;其他字符长度<=1,默认驻留8 x3 D- z' N) A% ?
    , A" V! R$ d5 s- y, ]
    乘数>=2时:仅含大小写字母,数字,下划线,总长度<=20,满足代码块的缓存机制
    ( @% U0 ?+ c( Z" A- H- |' [
    9 K5 e2 N, T  Z: s- S( B9 T' W; k, U  \8 W+ g9 f* t

    3 ?. H4 g' @5 V4 A" U# U  V) U四、总结
    6 \" V  \, ?! y9 l, G判断两个对象是否是同一个用 is,判断两个对象的值是否相等用 ==* y9 `( s( B/ g; J
    同一个代码块下适用一个缓存机制;不同代码块下适用另一个缓存机制(小数据池). N/ f; D( T) _5 H# C( z* M: @
    ————————————————! X9 R% h0 U1 d) e, r
    版权声明:本文为CSDN博主「阿玮d博客」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。8 Q/ t3 r$ J4 H) t  x: V+ q
    原文链接:https://blog.csdn.net/weixin_42511320/article/details/105650842
    4 d. _$ Y0 A; c) |/ [( P: \. v
    1 ~  W: a% r; ~; M3 s8 F) n6 e' h$ J8 }% e5 x) s3 x
    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-22 20:14 , Processed in 0.485424 second(s), 51 queries .

    回顶部