QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 3613|回复: 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,==
    % ?' A0 r1 r! ^! w5 U4 UPython中一切皆对象。对象包含三个要素,id、type、value。4 b$ P  p6 O- a9 u* m4 L

    : q! e/ l8 j, Xid 是对象的内存地址。每当我们创建一个对象的时候都会在内存中开辟一块空间,将这个对象的数据临时存放到内存中,id就是这个空间的唯一标号,就好比身份证号。9 Q0 t# A7 I8 f5 f+ k3 j
    $ N+ P5 ~8 m: [, p; L
    type 是对象的数据类型。包括 int(包括long)、float、string、list、tuple、dict、bool和NoneType 等。
    ) x3 ]" V& w; r: o8 H$ V- K) n6 ^& g5 [% D
    value 是对象指向的内存地址中存放的具体的值。2 c7 F% O, ~5 I9 K
    2 b- l/ p. D: X5 j
    因为在对象具有这些要素,所以我们用 is 和 == 两个表达式来判断两个对象是否”相等“7 g% w" X2 K8 j% M
    8 }) D( H$ s* [- S( `- v4 }+ g
    is 用于比较两个对象的地址(也就是 id)是否相同,而 == 用于比较两个对象引用的值是否相同
    3 r$ S6 a9 V& U9 a, b! J- O
    ! P6 ~0 F4 ?% K/ R; V+ Z9 [- ~  L  }: s# o
    我们也可以用身份证来理解:每个人都相当于一个对象,而身份证号(id)就唯一标识了世界上的每一个人;可能会存在姓名(value)相同(譬如两个人都叫阿玮),而身份证号不同的两个人。所以说如果内存地址相同,那么值肯定相同;但是如果值相同,内存地址不一定相同。/ m! X0 `! t3 L6 o* ?

    ! m3 p% U* S( X0 q% f! r二、代码块4 F* K. n3 {' V2 V& L% X9 Q
    Python程序是由代码块构造的。块是一个 Python 程序的文本,他是作为一个单元执行的  H& q3 C  _+ f: z3 w" E5 H! |$ W3 ?
    0 \1 G4 Y; l) d
    代码块:一个模块,一个函数,一个类,一个文件等都是一个代码块
    : _# z0 y, v8 x% G) V6 H. ~0 Z3 v3 Q
    而作为交互方式输入的每个命令都是一个代码块(如在 iPython)环境中,如:
    0 t7 L/ N' M/ X1 r' F
    0 B- ~6 |9 [& E$ x6 y$ g
    / S/ M; |# g5 _& O; I$ {而对于同一个文件中的两个函数,也属于两个分别的代码块:  N/ T) ~8 U( ?
    : R2 {! Y3 h: @; ^2 O* f' y% c

    " R* D& R" K' L- ]% s9 [代码块的缓存机制' L: t8 [* @$ \* {) I3 b2 V
    前提条件: 同一代码块/ M+ B4 K9 m3 K! E# a

    8 p1 J8 [1 R% D机制内容: Python在执行同一个代码块的初始化对象的命令时,会检查是否其值是否已经存在,如果存在,会将其重用。换句话说:执行同一个代码块时,遇到初始化对象的命令时,他会将初始化的这个变量与值存储在一个字典中,在遇到新的变量时,会先在字典中查询记录,如果有同样的记录那么它会重复使用这个字典中的之前的这个值。如下面的例子中,文件执行时(同一个代码块)会把 i1、i2 两个变量指向同一个对象,满足缓存机制则他们在内存中只存在一个,即:id 相同。0 D# b3 V2 s! @5 p% `/ @  v5 c+ J

    ( Q- L6 r( Q8 E  N" @$ A
    3 ?2 z# h! Y! N0 u9 r8 c: _% @! m9 `- _3 o+ |+ J6 n9 y$ t

    6 W" L* [) F8 d% s' y( ~0 [上面两张图分别为 Pycharm 中和 iPython 中对同一段代码的执行结果。可以看到在 Pycharm 中,代码以一个文件的形式来执行,i1 和 i2 指向了同一个对象;而在 iPython 中,i1 和 i2 是处于不同代码块中的,所以它们两个并不指向同一个对象: \6 G  E1 E# ?9 Q6 j: O

    4 a- Q8 x4 A4 c9 O' ^5 C适用对象: int(float),str,bool
    # ^: Z4 u4 w- I7 u2 ^& ?- ]! a& ~" @
    对象的具体细则:! q& g. p7 `6 I$ X! v

    * h8 s/ P" u. E# g5 _int(float):任何数字在同一代码块下都会复用
    6 U# D" i( H4 }8 M8 E; h4 Abool:True和False在字典中会以1,0方式存在,并且复用
    ' x% M# z% q# Ustr:几乎所有的字符串都会符合缓存机制
      T! n9 `. o! X  e# [非乘法得到的字符串都满足代码块的缓存机制. i# ^& q2 N. \( z: V2 e6 w
    乘法得到的字符串
    & t8 r4 M5 D5 C: T: T4 R" S$ @* w乘数为1时,任何字符串满足代码块的缓存机制9 y9 s  G# X- s6 T2 A6 ?: c- q2 t
    乘数>=2时:仅含大小写字母,数字,下划线,总长度<=20,满足代码块的缓存机制) J& L9 A3 {7 R( k2 r$ B2 u
    优点: 能够提高一些字符串,整数处理人物在时间和空间上的性能;需要值相同的字符串,整数的时候,直接从‘字典’中取出复用,避免频繁的创建和销毁,提升效率,节约内存7 B% B5 {. t) Q

    ( M1 T# g! ]2 @9 O  G# C+ j0 l" E+ T9 u1 y. ^& [, l
    + J4 h4 w" z# O
    三、小数据池
    / f! a  \. R' r0 t! H4 l8 h' w前提条件: 不同代码块内。
    , u. m( F& C% ^  t0 v7 V1 D2 i; N& F& ?1 N3 y: L
    适用的对象: int bool str
    # {4 X6 ~7 B: a% j3 z2 T- d
    , m7 r6 U0 ]( H- i具体细则:
      ?# X( J. n- ^8 I- n2 N4 n3 R
    ; [2 `; W% C6 k7 l% vint(float):-5~256
    + Z$ k) u6 r, Obool:True和False在字典中会以1,0方式存在,并且复用. N& h9 y' S, Z. p) [8 [& G
    str:满足规则的字符串
    + C: L( f; t: C7 @+ l& I. I4 Q字符串的长度为0或者1,默认都采用了驻留机制(小数据池)
    / \) `5 U; @' L1 l$ o4 ]0 U2 o
    4 @" P4 n8 l4 |3 _* y2 S9 e  E字符串的长度>1,且只含有大小写字母,数字,下划线时,才会默认驻留
    * u# X7 X# n- s* c4 }7 v6 Q' q+ d
    * ]8 `+ s( ]5 }( j, p5 m5 D用乘法得到的字符串3 r+ x; G  n$ n6 J* e
    乘数为1时,仅含大小写字母,数字,下划线;其他字符长度<=1,默认驻留
      s3 z: T/ Y) P6 ~' k2 o- B0 j" M9 P6 F
    乘数>=2时:仅含大小写字母,数字,下划线,总长度<=20,满足代码块的缓存机制2 m1 m6 r% ^+ [( y+ E7 a

    / `( U6 y1 ^; N8 ^# J# X3 I
    ( C" O' T9 Z6 U- F/ X0 b2 d) {; M: ~' a! b; l; V
    四、总结' D3 X9 j3 M" A! k" f# z
    判断两个对象是否是同一个用 is,判断两个对象的值是否相等用 ==: Q1 ~8 G( d2 u$ O) M; f
    同一个代码块下适用一个缓存机制;不同代码块下适用另一个缓存机制(小数据池)
    6 @2 S: `) _3 }% M$ E6 n" H————————————————+ b/ E5 }3 `3 \3 p, n" _8 N8 T
    版权声明:本文为CSDN博主「阿玮d博客」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。/ s6 ]% `6 B' U, m
    原文链接:https://blog.csdn.net/weixin_42511320/article/details/105650842
    2 j$ P$ ~9 Y  S/ v2 E; c( ~4 W4 `; k5 O% ?6 t

    ' f) F1 X( }/ G9 \" W& r- U! T$ C. 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, 2025-11-16 23:30 , Processed in 0.746617 second(s), 50 queries .

    回顶部