纤程与协程以及有栈协程和无栈协程的区别

2024-06-22 11:44

本文主要是介绍纤程与协程以及有栈协程和无栈协程的区别,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

纤程与协程区别以及有栈协程和无栈协程的区别

    • 参考
    • 纤程与协程区别
    • 有栈协程和无栈协程
    • 有栈协程为什么需要申请内存而无栈为什么不需要

参考

当谈论协程时,我们在谈论什么
从无栈协程到 C++异步框架(上)
从无栈协程到 C++异步框架(下)
libco
flare
这里不得不感叹下,鹅厂是真的不吝分享!!!

纤程与协程区别

本质上来,纤程和协程没有啥区别,都是可以暂停和恢复执行的函数,但是在概念上,两者是有区别的。
1、纤程是系统级别的。如linux的ucontext,windows的fiber(CreateFiber)。

爱奇艺有个跨平台开源项目叫libfiber,实现手段包含了ucontext和fiber。

2、协程是语言级别的,如go,rust,C#等提供的协程,c++如libco,libaco,boost::coroutine等等。

有栈协程和无栈协程

如何区分有栈和无栈协程?或者说为什么区分为有栈和无栈?
原因就是有栈协程需要申请内存供协程执行,而无栈协程则不需要申请。

有栈协程为什么需要申请内存而无栈为什么不需要

协程即可以暂停和恢复执行的函数。当下程序的运行需要依赖寄存器,函数执行过程中如何跳转到其他函数,在没有协程的情况下可通过return,直接调用其他函数实现,但这中做法无法恢复执行原来的函数。
所以需要保存下来当前函数执行时的堆栈信息(如何ebp,esp等),想要恢复(resume)时则将上一个协程中保存的寄存器相关信息加载到寄存器即可。而保存这一操作必然需要额外的内存。
为什么无栈协程不需要呢?
无栈协程的做法靠的是C语言特性switch case嵌套do while,这一做法也被称作duff device(达夫设备),通过Switch跳转至上次运行的地方,从无栈协程到 C++异步框架(上)已进行详细描述,不在赘述。

这篇关于纤程与协程以及有栈协程和无栈协程的区别的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1084198

相关文章

hevc和H.264格式的区别

HEVC(High Efficiency Video Coding)和H.264(也称为Advanced Video Coding,AVC)都是视频压缩标准,但它们之间存在一些显著的区别,主要集中在压缩效率、资源需求和兼容性方面。 压缩效率 HEVC,也被称为H.265,提供了比H.264更高的压缩效率。这意味着在相同的视频质量下,HEVC能够以大约一半的比特率进行编码,从而减少存储空间需求和

Java面试题:通过实例说明内连接、左外连接和右外连接的区别

在 SQL 中,连接(JOIN)用于在多个表之间组合行。最常用的连接类型是内连接(INNER JOIN)、左外连接(LEFT OUTER JOIN)和右外连接(RIGHT OUTER JOIN)。它们的主要区别在于它们如何处理表之间的匹配和不匹配行。下面是每种连接的详细说明和示例。 表示例 假设有两个表:Customers 和 Orders。 Customers CustomerIDCus

Eclipse+ADT与Android Studio开发的区别

下文的EA指Eclipse+ADT,AS就是指Android Studio。 就编写界面布局来说AS可以边开发边预览(所见即所得,以及多个屏幕预览),这个优势比较大。AS运行时占的内存比EA的要小。AS创建项目时要创建gradle项目框架,so,创建项目时AS比较慢。android studio基于gradle构建项目,你无法同时集中管理和维护多个项目的源码,而eclipse ADT可以同时打开

在 Java 中,JDK、JRE、JVM 分别代表什么,有何关系和区别?

在Java开发的世界中,我们会经常听到JDK、JRE和JVM这三个词。它们都与Java的运行环境以及Java程序的编译和运行有关,它们之间也存在一些关联性和区别。 什么是JDK、JRE和JVM 我们来看它们分别是什么。 JDK,全称Java Development Kit,即Java开发工具包。顾名思义,JDK是用于Java开发的一套工具包,里面包含了Java的编译器javac、

QT 中ListView和ListWidget有什么区别

ListView和ListWidget在Qt框架中都是用于显示列表数据的控件,但它们在使用方法和特性上存在一些明显的差异。以下是关于它们用法不一样的地方的详细分析: 数据管理方式: ListView:使用QAbstractItemModel数据模型来管理和显示列表数据。QAbstractItemModel是一个抽象类,允许开发者自定义数据模型以适应特定的数据结构和需求。这使得ListView在处

Transformers和Langchain中几个组件的区别

1.对于Transformers框架的介绍 1.1 介绍: transformers 是由 Hugging Face 开发的一个开源库,它提供了大量预训练模型,主要用于自然语言处理(NLP)任务。这个库提供的模型可以用于文本分类、信息抽取、问答、文本生成等多种任务。 1.2 应用场景: 文本分类:使用 BERT、RoBERTa 等模型进行情感分析、意图识别等。命名实体识别(NER):使用序列

java的clone() 深克隆与浅克隆的区别

克隆的目的:快速创建一个已有对象的副本。 克隆的步骤: 创建一个对象将原有对象的数据导入到新创建的数据中 1. Object的clone()源代码简介 [java]  view plain copy /**   * Creates and returns a copy of this {@code Object}. The default   * i

HTTP状态码中301与302的区别

一.官方说法  301,302 都是HTTP状态的编码,都代表着某个URL发生了转移,不同之处在于:  301 redirect: 301 代表永久性转移(Permanently Moved)。  302 redirect: 302 代表暂时性转移(Temporarily Moved )。  这是很官方的说法,那么它们的区别到底是什么呢?  1.1、什么是301转向?什么是301重定向?

什么是dB?dBm、dBc、dBi、dBd怎么计算,有什么区别?

什么是dB?dBm、dBc、dBi、dBd怎么计算,有什么区别? 引言 在电子工程、通信和音频领域,dB(分贝)是一个常见的术语。许多人刚接触时可能会感到困惑,因为它不仅仅是一个简单的单位,还有多种不同的形式,如dBm、dBc、dBi和dBd。这篇文章将详细解释这些概念,并介绍如何计算它们,帮助初学者更好地理解和应用。 什么是dB? dB,即分贝,是一种表示两个数值比值的对数单位。分贝的基

工程师 - status和state的区别

"Status"和 "state"是相关的概念,但有不同的含义,尤其是在计算、系统和编程方面: 1. Status:     * 定义: 状态是指系统、进程或实体在某一特定时间点的当前状态或情况。     * 使用方法: 它通常描述一项操作的状态,如是否正在进行、是否已成功完成、是否遇到错误或是否正在等待输入。     * 举例说明: 在编程中,函数可能会返回一个状态代码,