QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 3377|回复: 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,==" m8 m+ n+ o0 w6 j: X* R
    Python中一切皆对象。对象包含三个要素,id、type、value。
    3 e, a3 T. b) W. p% B/ }2 _8 }! Z( ^& h! |' w+ E* ?. l. I" M
    id 是对象的内存地址。每当我们创建一个对象的时候都会在内存中开辟一块空间,将这个对象的数据临时存放到内存中,id就是这个空间的唯一标号,就好比身份证号。
    / h  `" m5 s5 S7 T3 ~) u" n) e8 }9 ]- I
    type 是对象的数据类型。包括 int(包括long)、float、string、list、tuple、dict、bool和NoneType 等。
    : \% L- `5 t! u6 S: o- F" i( b$ ?) t( X9 o" w
    value 是对象指向的内存地址中存放的具体的值。
    + r7 V6 u" m9 O0 f. y$ {  z4 B3 X( L) {3 e7 S. }3 y" }* x
    因为在对象具有这些要素,所以我们用 is 和 == 两个表达式来判断两个对象是否”相等“
    6 Q+ V1 I$ v/ x
    & j6 x9 B2 Y2 M8 gis 用于比较两个对象的地址(也就是 id)是否相同,而 == 用于比较两个对象引用的值是否相同
    ; ]! y8 v: H6 T+ i+ q3 o2 ~& r3 ~
    ' [/ [# V: T; K8 y# F* H! r1 Y- E8 s' M9 r% @; d+ O
    我们也可以用身份证来理解:每个人都相当于一个对象,而身份证号(id)就唯一标识了世界上的每一个人;可能会存在姓名(value)相同(譬如两个人都叫阿玮),而身份证号不同的两个人。所以说如果内存地址相同,那么值肯定相同;但是如果值相同,内存地址不一定相同。( O5 \1 M2 ~' N0 f, M8 I2 n  S
    % \$ O, d, S) ?7 a8 [8 X- J! N5 r3 e$ j
    二、代码块
    ) z1 U1 |: X% {3 U6 \Python程序是由代码块构造的。块是一个 Python 程序的文本,他是作为一个单元执行的
    / d3 q6 N  d" E4 C$ J  i  P( e4 g+ z8 n9 e& E( m$ W& ?6 f
    代码块:一个模块,一个函数,一个类,一个文件等都是一个代码块% X9 C6 R7 ^( G# Z1 ^  n' Z- l9 q/ m

    ( B. z2 [5 `( Z7 `. y而作为交互方式输入的每个命令都是一个代码块(如在 iPython)环境中,如:
    3 ~! ?6 h" ^6 G% ?) E' P) c4 R+ n8 H1 x7 j" W
    ' \& Q$ o) V) x) a" _1 p
    而对于同一个文件中的两个函数,也属于两个分别的代码块:7 E$ I& Q2 L# S/ X' M

    1 R, s6 {2 i) Q
    / J2 I5 d7 T' R4 `+ V6 e代码块的缓存机制+ d: g# r& a( x% C
    前提条件: 同一代码块
    0 K# G8 h: `: t6 o# u- w4 y. F* M, R1 g% Z
    机制内容: Python在执行同一个代码块的初始化对象的命令时,会检查是否其值是否已经存在,如果存在,会将其重用。换句话说:执行同一个代码块时,遇到初始化对象的命令时,他会将初始化的这个变量与值存储在一个字典中,在遇到新的变量时,会先在字典中查询记录,如果有同样的记录那么它会重复使用这个字典中的之前的这个值。如下面的例子中,文件执行时(同一个代码块)会把 i1、i2 两个变量指向同一个对象,满足缓存机制则他们在内存中只存在一个,即:id 相同。. f8 v8 v. w& ~! ~& l1 T2 e
    , |9 I1 H: b8 `+ A. f  b3 L! r
    ' A7 K. r7 Y$ N* q( k- j4 x
    : Y  _. w, D4 q, _  B
    6 I; r; Z+ p& C' `
    上面两张图分别为 Pycharm 中和 iPython 中对同一段代码的执行结果。可以看到在 Pycharm 中,代码以一个文件的形式来执行,i1 和 i2 指向了同一个对象;而在 iPython 中,i1 和 i2 是处于不同代码块中的,所以它们两个并不指向同一个对象/ O, ]( v2 }3 o' u" m
    ' _2 ]- x$ i% ^' {5 s7 [4 K9 u
    适用对象: int(float),str,bool
    7 V: d9 S4 l4 \' [( r0 W
    3 o! i9 S9 v+ w' w对象的具体细则:
    " ?: C! T5 _) }$ W
    - W% Q  j0 X$ Rint(float):任何数字在同一代码块下都会复用
    6 q. u) s/ [  t3 S' {' Nbool:True和False在字典中会以1,0方式存在,并且复用$ H) ^* K) \8 y0 L. T
    str:几乎所有的字符串都会符合缓存机制
    % T- x7 D7 ?- v9 h/ ^非乘法得到的字符串都满足代码块的缓存机制
    3 \$ Q+ {" E9 s* `* l乘法得到的字符串6 U* n4 |* f- l# X( q! Q% U. k
    乘数为1时,任何字符串满足代码块的缓存机制
    7 f3 v. R, z$ _  H1 \乘数>=2时:仅含大小写字母,数字,下划线,总长度<=20,满足代码块的缓存机制" V7 y+ L: [' ?( g4 w/ a0 A4 Z
    优点: 能够提高一些字符串,整数处理人物在时间和空间上的性能;需要值相同的字符串,整数的时候,直接从‘字典’中取出复用,避免频繁的创建和销毁,提升效率,节约内存
    " J: ~# _( S8 @7 _* a: ~( g
    & q" {& }' w$ h( g% A. f8 t6 l3 J$ g$ D
    . Y4 `" ~5 g6 O; s- ^
    三、小数据池% ]6 I5 I0 M! @7 G" e
    前提条件: 不同代码块内。
    , J% [  B5 p# P' j8 s- o& S* l5 U% M7 S% h+ F
    适用的对象: int bool str
    " y7 ]6 Z( Q1 S2 T. g$ x* O9 s( ~) I0 }2 q6 c
    具体细则:$ M' C4 j1 T- e: i3 \
    ; u. s& `% c/ d: J7 w( ]: ?
    int(float):-5~256
    ' b- Z4 j8 p0 r9 d! obool:True和False在字典中会以1,0方式存在,并且复用" E  L0 j; d$ y9 k1 j
    str:满足规则的字符串* s( l1 s% T9 @& a& M
    字符串的长度为0或者1,默认都采用了驻留机制(小数据池); e7 f# {" s2 v& u
    0 J+ |9 {5 Y! w0 O+ @" g; Y  g: g
    字符串的长度>1,且只含有大小写字母,数字,下划线时,才会默认驻留
    ; z; |+ {0 ]* _
    # n) E$ W) f! j0 d* F2 x! \用乘法得到的字符串
    # \) D0 G8 T2 \  \6 g5 m6 m+ _乘数为1时,仅含大小写字母,数字,下划线;其他字符长度<=1,默认驻留  I5 e4 g) T% ~, ?2 [& P( U

    : I3 ]$ z; f: b. V0 }" l乘数>=2时:仅含大小写字母,数字,下划线,总长度<=20,满足代码块的缓存机制
    & o- W5 d# H% {, C, K4 C% `5 R
    ) |$ f& a6 _) q' x  f* c9 R4 f2 y: c2 w6 _

    ( U7 G! G) d! _' r0 R1 u3 O3 |# q4 z四、总结' S4 i4 W% {7 C4 m/ h& l& t
    判断两个对象是否是同一个用 is,判断两个对象的值是否相等用 ==
    ) O4 i# ^6 W5 ^5 x) j3 K* W同一个代码块下适用一个缓存机制;不同代码块下适用另一个缓存机制(小数据池)
    5 R( Y9 b& y2 g1 o$ Q————————————————+ O' U1 n& v' Z, Q1 k- ~& j
    版权声明:本文为CSDN博主「阿玮d博客」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。4 _3 _' U  a6 ~! I* k
    原文链接:https://blog.csdn.net/weixin_42511320/article/details/105650842
    , l- o! J( ?1 L/ c( d% ?( v" y1 M7 q# F4 }, L9 |# L9 ?+ j/ v) G$ X2 G

    ( |) z( ?7 j8 r# B" K9 p
    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-8-13 16:27 , Processed in 0.531683 second(s), 50 queries .

    回顶部