摘要: GeventGevent 是一个第三方库,可以轻松通过gevent实现并发同步或异步编程,在gevent中用到的主要模式是Greenlet, 它是以C扩展模块形式接入Python的轻量级协程。 Greenlet全部运行在主程序操作系统进程的内部,但它们被协作式地调度。示例import gevent#gevent,自动挡切换def func1(): print('Ashley starts r... 阅读全文
posted @ 2020-01-02 18:17 InfiniteCodes 阅读(144) 评论(0) 推荐(0) 编辑
摘要: 协程协程,又称微线程,纤程。英文名coroutine。简单说:协程是一种用户态的轻量级线程。协程拥有自己的寄存器上下文和栈。写成调度切换时,将寄存器上下文和栈保存到其他地方,在且回来的时候,恢复先前保存的寄存器上下文和栈。因此,协程能保留上一次调用时的状态(即所有局部状态的一个特定组合),每次过程重入时,就相当于进入上一次调用的状态,换句话说:进入上一次离开时所处逻辑流的位置。协程的优点:无需线程... 阅读全文
posted @ 2020-01-02 17:07 InfiniteCodes 阅读(132) 评论(0) 推荐(0) 编辑
摘要: 进程池进程池内部维护一个进程序列,当使用时,则去进程池中获取一个进程,如果进程池序列中没有可供使用的进进程,那么程序就会等待,直到进程池中有可用进程为止。进程池中有两个方法:apply apply_async串行示例from multiprocessing import Process, Poolimport time, osdef f(i): time.sleep(1) print(... 阅读全文
posted @ 2019-12-31 21:39 InfiniteCodes 阅读(149) 评论(0) 推荐(0) 编辑
摘要: 进程间数据交互我们知道,两个独立进程所使用的内存空间也是独立的,不可交互的。但现实中就有那么些情况需要两个进程可以互相通信,怎么办?我们需要一个中继、翻译、中间人,不管你叫他什么,只要知道他是用来转发数据的就行了。Python中的这个中间人就叫queue,不是线程queue,是进程queue。使用方法和线程queue差不多。示例如下:from multiprocessing import Proc... 阅读全文
posted @ 2019-12-31 20:39 InfiniteCodes 阅读(161) 评论(0) 推荐(0) 编辑
摘要: 多进程的第一个示例import multiprocessingimport threadingimport timedef thread_run(): print(threading.get_ident()) #子线程输出线程ID号def run(name): time.sleep(2) print('Hello ', name) t = threading.Thre... 阅读全文
posted @ 2019-12-31 19:22 InfiniteCodes 阅读(144) 评论(0) 推荐(0) 编辑
摘要: 首先,我们直到Python多线程是假多线程,实际上同一时刻只有一个核在执行任务。其次,要知道IO(INPUT/OUPUT)操作不占用CPU,但计算会占用CPU。所以,Python多线程不适合CPU密集操作型任务;适合IO操作密集型任务,比如SocketServer就属于IO操作密集型。如何才能用到CPU更多的核?由于两个独立进程之间不能通信,此时GIL会失效,GIL只对Python代码起作用,而无... 阅读全文
posted @ 2019-12-31 11:58 InfiniteCodes 阅读(86) 评论(0) 推荐(0) 编辑
摘要: GIL(Global Interpreter Lock)全局解释器锁In CPython, the global interpreter lock, or GIL, is a mutex that prevents multiple native threads from executing Python bytecodes at once. This lock is necessary main... 阅读全文
posted @ 2019-12-30 23:30 InfiniteCodes 阅读(249) 评论(0) 推荐(0) 编辑
摘要: queue队列日,这篇好长啊….queue is especially useful in threaded programming when information must be exchanged safely between multiple threads.多线程编程环境下,当在多条线程中,信息必须被安全的交换时,queue尤其有用。class queue.Queue(maxsize=0... 阅读全文
posted @ 2019-12-30 23:21 InfiniteCodes 阅读(121) 评论(0) 推荐(0) 编辑
摘要: 类Fabric主机管理工具开发要求:主机分组登陆后显示主机分组,选择分组后查看主机列表可批量执行命令、发送文件,结果实时返回主机用户名密码不同 阅读全文
posted @ 2019-12-30 22:01 InfiniteCodes 阅读(119) 评论(0) 推荐(0) 编辑
摘要: EventsAn event is a simple synchronization object;一个事件就是一个简单的同步对象;the event represents an internal flag, 事件代表一个内部标记,and threads can wait for the flag to be set, or set or clear the flag themselves.并且线... 阅读全文
posted @ 2019-12-30 11:01 InfiniteCodes 阅读(185) 评论(0) 推荐(0) 编辑