很多时候python都被人称为玩具语言,很多人看不起python,觉得它们不如Java,golang,c这些语言的高效,也不如bash这些脚本语言正统,然而我想说的是,存在即合理,特别是python占有这么多的市场份额就足以说明它的使用价值,我们都知道python学起来很简单,那么python是不是就没有复杂的技术需要深入学习了呢?接下来我就谈一谈python中那些并不简单的技术。
0 F7 N- q3 i' E1 ?1、元编程' l5 {" \% Z; [
简单来说,元编程就是可以操作目标语言的语言,比如说,我有一个类,我想要在生成类的时候,获取到类的信息,那么这个过程就是元编程。
1 @& C% \, r* z 如果你有了解过反射的话,你会发现这和反射很像,没错,反射就是实现元编程的一种方法。
% I R% T Y. X9 L( d5 J 在python中,一般通过魔术方法,描述符,元类和eval来实现元编程。. u& e! z( b2 J
2、GIL
" S! Q$ L! Y6 L J. Q GIL的全称是global interpreter lock,叫做全局解释器锁。: K* m% V) [. i; n8 J& g
我们都知道操作系统调度的最小单位是线程,而一个进程中可以存在多个线程,当多个线程并发一起运行的时候,它们可能会修改同一块内存,造成数据的不一致,为了解决这个问题,cpython解释器会让每个线程去获取GIL,只有成功获取到GIL的线程才能够执行,其它的线程需要等待,而这就是python的线程并发是伪并发的原因。
- [$ M8 g. ^% K0 P; z: ~$ V1 c 那么如何更好地利用多核cpu呢,最简单的办法就是使用多进程,因为GIL是在线程中独有的,而进程中不需要获取它,因此通过运行多个进程就可以实现程序的并发执行。5 @7 o. M# c7 \- D: V7 ^' H; \( D" E
3、协程0 }' k. i- X9 U$ K) G
我们知道操作系统调度的最小单位是线程,那么协程是什么呢?通俗地讲,协程就是用户态线程,也就说,我们封装了一个线程,在这个线程中,我们可以自己进行调度,当执行耗时的操作时候,我们让出执行的任务,去执行其它的任务,也就是让cpu看到我们的线程一直在执行任务而没有等待。
2 l* r6 w& C* o5 }* @
' `0 U) ?7 H( l8 }
python中通过yield关键字进行协程的调度,通过yield可以保存任务状态,通过send关键字可以函数结果传递给另一个函数。
0 V5 ?, g2 a0 s4、上下文管理器( E$ |% q' v+ T3 G* X
我们平时在操作文件或者数据库的时候,当我们使用之后,都需要手动关闭它们,那么我们有没有办法自动释放资源呢?答案是肯定的,我们可以使用with关键字。, q: u9 k( y- K7 e9 m8 `
with open('test.txt') as f:
print f.readlines() 通过这样的操作,我们在函数执行之后,就会自动释放文件资源。! ~2 b# ?5 D9 N
上下文管理器是如何实现的呢,它的原理就是它的底层实现了__enter__和__exit__方法,这样在执行函数主体之前,我们可以先执行enter方法,主体执行之后,我们再执行exit方法。+ H! J/ _. r& w' v: ^8 Y
python中通过contextlib装饰器,可以优雅地实现上下文管理器。5 v6 L/ E# P& |3 ^1 F; W5 P0 U b
5、装饰器
/ q" S9 X( u9 A: Q1 j 顾名思义,装饰器就是对函数的一个装饰,它在不修改函数主体内容的时候,对函数进行装饰,让它看起来变得不太一样。3 Z$ H8 l8 E- E+ t# ?# k% U V
( c! E! O; o: `; ^( X; l0 j python中通过在函数前面加上@符号,可以轻松地对函数进行装饰,很多日志功能还有授权功能,通过装饰器的使用都会变得更加优雅。
8 m, o9 J. f& j5 T# f6、闭包
8 p4 g# ?, p& Q& q3 G 闭包是很多语言都会有的概念,在python中,闭包就是函数的嵌套,不过这不是简单的函数嵌套,它需要满足几个条件。" M- s) c8 u1 j, k: Q; x! S
# M, N4 o. c/ d; _+ [* K- w2 M 外部函数返回值是内部函数的引用
' \/ m/ V3 C8 d( m- H2 D, Y6 r nonlcoal 修改外部参数7 O5 q9 J7 s: S4 z0 S3 \, E8 ^+ J
python通过闭包的使用,可以更加方便地实现装饰器。
' J' e6 S) w4 H1 ^9 x6 i4 [
- L0 R, ?; C7 b' O% l. p1 ~ |