`
febird
  • 浏览: 256443 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

process-->thread-->coroutine

    博客分类:
  • C++
阅读更多

在现实世界中,基本是是按着这样的顺序演化:process-->thread-->coroutine/fiber

其实是一个context切换开销从大到小的演化,process切换开销最大,需要切换地址空间,所有的CPU状态,所有其他资源

thread切换只需要切换CPU状态,当然是大部分的CPU状态,而coroutine切换,只需要切换很少的CPU状态,而且全部都在用户地址空间运行,不需要到内核空间。

当然,切换coroutine的开销还是比一次函数调用大很多,其实函数调用也是一个cpu状态的切换,不过这个状态要少得多,在x86 windows 上,甚至不必保存所有的寄存器状态(EAX/ECX/EDX在函数调用之间就不用保证,EAX保存返回值),有些调用甚至通过寄存器传递参数……比起coroutine,太微不足道了。

coroutine其实也可以看成是一个保留了以前调用状态(另一个堆栈帧)的函数调用,在寄存器很多的系统上(如Itanium),切换寄存器状态的开销还是比较大的,如果哪一天大家又开始嫌coroutine也太慢,那怎么办?

分享到:
评论

相关推荐

    多任务_python多任务_

    threads = [threading.Thread(target=task, args=("Thread 1",)), threading.Thread(target=task, args=("Thread 2",))] for thread in threads: thread.start() # 启动线程 for thread in threads: thread.join()...

    线程与并发:Ruby并行世界的探索之旅

    - **协程 (Coroutine)**:一种可暂停和恢复执行的程序组件。 Ruby 支持多种并发模型,包括多线程、多进程及使用协程库(如 Goliath 或 Reel)。下面是一个使用进程进行并发处理的示例代码: ```ruby require '...

    多协程、多线程、多进程代码

    print(f"Coroutine is running") loop = asyncio.get_event_loop() tasks = [worker() for _ in range(5)] loop.run_until_complete(asyncio.gather(*tasks)) loop.close() ``` 在实际应用中,根据任务特性...

    《Python Cookbook》第三版中文

    - **协程(Coroutine)**:Python 3.5引入的`asyncio`库,支持异步编程和非阻塞I/O。 9. **性能优化**: - **内建函数(Built-in Function)**:了解哪些内建函数比自定义函数更高效。 - **Cython和NumPy**:...

    Python编程实战-运用设计模式、并发和程序库创建高质量程序.pdf

    Python提供了多种并发模型,如线程(Thread)、进程(Process)、协程(Coroutine)和异步I/O(例如asyncio库)。并发能够提高程序性能,但同时也引入了竞态条件和死锁等问题,因此,学习如何管理和调试并发代码是...

    Web并发模型粗浅探讨

    3. 多进程加多线程(multi-process+multi-thread):如Python的全局解释器锁(GIL),允许一个进程中存在多个线程,但同一时刻只有一个线程在执行Python字节码。 4. 事件I/O(event I/O):又称为异步非阻塞I/O模型...

    py代码-12345

    - 异步I/O:asyncio模块,支持协程(coroutine)和事件循环。 10. **调试与测试**: - 调试工具:pdb模块提供交互式调试器。 - 单元测试:unittest模块,用于编写和运行测试。 以上是Python编程中的核心概念,...

    python3.6.5参考手册 chm

    Changes to the Development Process New Issue Tracker: Roundup New Documentation Format: reStructuredText Using Sphinx PEP 343: The ‘with’ statement Writing Context Managers The contextlib module ...

    Learning Concurrency in Python

    - **线程对象的创建与启动**:使用`Thread`类创建线程对象,并调用其`start()`方法来启动线程。 - **线程同步**:为了防止数据竞争和死锁,需要使用`Lock`或`RLock`等同步机制来保护共享资源。 - **线程通信**:通过...

    FC线程库模型介绍

    在FC线程模型中,线程(thread)和协程(coroutine/fiber)是两个核心概念。线程是操作系统能够进行运算调度的最小单位,它被包含在进程之中,是进程中的实际运作单位。而协程,它是一种用户态的轻量级线程,由...

    php_swoole_loader_2.2_php7.3_zts widows-x64版本

    3. **协程(Coroutine)**:Swoole的协程机制使得开发者无需关心底层的异步编程细节,只需按照同步方式编写代码,就能实现异步执行。 4. **定时器(Timer)**:提供定时任务功能,可以设置定时回调函数,用于执行...

    面试预备

    - **线程(Thread)与进程(Process)**:理解两者的区别,以及在Python中如何使用threading和multiprocessing模块。 - **协程(Coroutine)**:了解asyncio库,使用async/await进行异步编程。 6. **Web开发**: ...

    操作系统key words中英文整合(以字母排序)

    31. Coroutine(协同程序):一种程序执行方式,它允许在不同子程序之间主动让出控制权。 32. Counting semaphore(计数信号量):可以有多个值的信号量,允许多个进程同时访问共享资源。 33. Critical resource...

    详解python程序中的多任务

    通过协程(Coroutine)机制,可以有效地避免阻塞,提高程序的响应速度。 - 示例代码: ```python import asyncio async def sing(): for i in range(5): print("正在唱") await asyncio.sleep(1) ...

    python:https

    Python 2.7 基础 实现switch ...process、thread、coroutine socket algorithm largeLog tail token Web框架 Flask django tornado RESTFUL API API 学习资料 编程规范 Python进阶 Google开源项目风格指南

    python shell

    3. **异步IO**:Python的asyncio库基于协程(coroutine)实现异步编程,它允许多个任务在单个线程内并发执行,而不是真正意义上的多线程或多进程。通过定义`async def`函数来创建协程,并使用`await`关键字等待异步...

    Python语言多进程与多线程设计探究.zip

    2. `multiprocessing`模块:Python提供了`multiprocessing`模块来支持多进程编程,其中包含Process类,可以创建并管理新的进程。 3. 进程间通信:多进程间通过Queue、Pipe等方式进行通信,传递数据。 4. 并行优势:...

    python线程、进程和协程详解

    print(f'Coroutine {num} running...') await asyncio.sleep(1) async def main(): tasks = [worker(i) for i in range(5)] await asyncio.gather(*tasks) if __name__ == '__main__': asyncio.run(main()) `...

    concurrency:适用于各种并发任务的小片段解决方案

    它提供了Process类来创建进程,并通过Queue、Pipe等方式进行进程间通信。 3. **threading**: threading库是Python的标准线程库,它允许你在同一进程内创建多个线程。线程共享进程的内存空间,因此它们之间的通信更...

    python如何支持并发方法详解

    通过协程(coroutine)和事件循环,Python可以实现非阻塞I/O,提高I/O密集型应用的效率。在异步编程中,程序可以同时处理多个任务,而不是等待一个任务完成后再执行下一个。 4. **Greenlet和Gevent**: Greenlet是...

Global site tag (gtag.js) - Google Analytics