python的猴子补丁monkey patch

monkey patch指的是在运行时动态替换,一般是在startup的时候.

用过gevent就会知道,会在最开头的地方gevent.monkey.patch_all();把标准库中的thread/socket等给替换掉.这样我们在后面使用socket的时候可以跟平常一样使用,无需修改任何代码,但是它变成非阻塞的了.

一个比较实用的例子,很多代码用到 import json,后来发现ujson性能更高,如果觉得把每个文件的import json 改成 import ujson as json成本较高,或者说想测试一下用ujson替换json是否符合预期,只需要在入口加上:

1 import json
2 import ujson
3
4 def monkey_patch_json():
5     json.__name__ = ‘ujson‘
6     json.dumps = ujson.dumps
7     json.loads = ujson.loads
8
9 monkey_patch_json()

最后,注意不能单纯的json = ujson来替换.

原文地址:https://www.cnblogs.com/robert871126/p/10107127.html

时间: 2024-11-05 15:51:48

python的猴子补丁monkey patch的相关文章

python中的猴子补丁Monkey Patch

python中的猴子补丁Monkey Patch 什么是猴子补丁 the term monkey patch only refers to dynamic modifications of a class or module at runtime, motivated by the intent to patch existing third-party code as a workaround to a bug or feature which does not act as desired

什么是猴子补丁(monkey patch)

monkey patch指的是在运行时动态替换,一般是在startup的时候. 用过gevent就会知道,会在最开头的地方gevent.monkey.patch_all();把标准库中的thread/socket等给替换掉.这样我们在后面使用socket的时候可以跟平常一样使用,无需修改任何代码,但是它变成非阻塞的了. 之前做的一个游戏服务器,很多地方用的import json,后来发现ujson比自带json快了N倍,于是问题来了,难道几十个文件要一个个把import json改成import

Python之猴子补丁

1.在运行时,对属性,方法,函数等进行动态替换 2.其目的往往是为了通过替换,修改来增强,扩展原有代码的能力 #test2.py class Person: def get_score(self): ret = {'english':80,'history':100,'chinese':150} return ret #test3.py def get_score(self): return dict(name=self.__class__.__name__,english=100,chines

Python Monkey patch猴子补丁

monkey patch (猴子补丁)   用来在运行时动态修改已有的代码,而不需要修改原始代码. 简单的monkey patch 实现:[python] #coding=utf-8 def originalFunc():     print 'this is original function!'      def modifiedFunc():     modifiedFunc=1     print 'this is modified function!'      def main():

Python面试题之“猴子补丁”(monkey patching)指的是什么?这种做法好吗?

“猴子补丁”就是指,在函数或对象已经定义之后,再去改变它们的行为. 举个例子: import datetime datetime.datetime.now = lambda: datetime.datetime(2012, 12, 12) 大部分情况下,这是种很不好的做法 - 因为函数在代码库中的行为最好是都保持一致.打“猴子补丁”的原因可能是为了测试.mock包对实现这个目的很有帮助. 为什么提这个问题? 答对这个问题说明你对单元测试的方法有一定了解.你如果提到要避免“猴子补丁”,可以说明你不

python 高级一点的用法,猴子补丁与元类

好久没更新了,今天想想哪些要记录下的,装饰器什么的就不说了,很熟悉了,记录下. 1.monkey patch. 其实就是动态修改类,包括属性方法等的一种方式. 比如a = A() a.foo = foo之类的,但是怎么在运行前修改呢,类似gevent那样用自己的socket替换, gevent 源码是这样的 from eventlet.green import socket patcher.inject('ftplib', globals(), ('socket', socket)) 然后inj

python 模块会导入几次?猴子补丁为什么可以实现?

一共三个文件 a.py内容是 print('被导入') x = 1 b.py内容是 import a a.x = 2 c.py内容是 import a import b print(a.x) 现在运行c文件,这个结果出乎很多人的意料大部分python人员都猜不对,结果是 1.可以发现a模块被两个地方导入了,但是只打印一次 “被导入”. 2.在c文件里面不管是先导入a还是导入b,打印x的结果都是2. 不光是自己的文件如此,导入库文件也是一样.所以这就是猴子补丁能实现的原因. 2.再多想一下,为什么

第二种方式,修改python unittest的执行顺序,使用猴子补丁

1.按照测试用例的上下顺序,而不是按方法的名称的字母顺序来执行测试用例. 之前的文章链接 之前写的,不是猴子补丁,而是要把Test用例的类名传到run里面去执行,与原生的使用有一点区别.现在修改成,用的时候代码与原生unittest完全一模一样,但运行时候使用与原生不同的逻辑. import time import unittest from unittest.main import TestProgram from app.utils.utils_ydf import LogManager c

python协程初步--gevent库使用以及解释什么是猴子补丁monkey_patch

协程工作的特点是遇到阻塞或耗时的任务时就切换,协程的生存依赖于线程,线程依赖于协程 一个似乎有点问题的例子 import gevent,time def kisscpc(num): for i in range(num): print ("吻了第%s下陈培昌"%(i+1),gevent.getcurrent()) time.sleep(1) def kisscj(num): for i in range(num): print ("吻了第%s下程劲"%(i+1),g