协程和多线程有什么区别呢?
一、协程和多线程的区别
1.由于协程的特性, 适合执行大量的I/O 密集型任务, 而多线程在这方面弱于协程。
2.协程涉及到函数的切换,多多线程涉及到多线程的切换, 所以都有执行上下文, 但是协程不是被操作系统内核所管理, 而完全是由程序所控制(也就是在用户态执行), 这样带来的好处就是性能得到了很大的提升, 不会像多线程那样需要在内核态进行上下文切换来消耗资源,因此协程的开销远远小于多线程的开销。
3.同一时间, 在多核处理器的环境下, 多个多线程是可以并行的,但是运行的协程的函数却只能有一个,其他的协程的函数都被suspend, 即协程是并发的。
4.由于协程在同一个多线程中, 所以不需要用来守卫临界区段的同步性原语(primitive)比如互斥锁、信号量等,并且不需要来自操作系统的支持。
5.在协程之间的切换不需要涉及任何系统调用或任何阻塞调用。
6.通常的多线程是抢先式(即由操作系统分配执行权), 而协程是由程序分配执行权。
延伸阅读:
二、协程的原理
当出现IO阻塞的时候,由协程的调度器进行调度,通过将数据流立刻yield掉(主动让出),并且记录当前栈上的数据,阻塞完后立刻再通过线程恢复栈,并把阻塞的结果放到这个线程上去跑,这样看上去好像跟写同步代码没有任何差别,这整个流程可以称为coroutine,而跑在由coroutine负责调度的线程称为Fiber。比如Golang里的 go关键字其实就是负责开启一个Fiber,让func逻辑跑在上面。
由于协程的暂停完全由程序控制,发生在用户态上;而线程的阻塞状态是由操作系统内核来进行切换,发生在内核态上。
因此,协程的开销远远小于线程的开销,也就没有了ContextSwitch上的开销。
以上就是关于协程和多线程有什么区别的内容希望对大家有帮助。

相关推荐HOT
更多>>
chatgpt将带来哪些影响?
ChatGPT是一个大型的人工智能语言模型,由OpenAI进行训练。它的出现将对人工智能技术产生重要影响,并在诸多领域产生重要影响。1.提高人工智能...详情>>
2023-10-11 17:16:23
Hibernate 和 Spring Data JPA有哪些区别?
一、Hibernate 和 Spring Data JPA的区别1、功能不同Hibernate是一个ORM(对象关系映射)框架,用于在Java应用程序中管理数据库的访问和操作;...详情>>
2023-10-11 16:26:07
什么是用户体验 (UX) 设计?
一、什么是用户体验 (UX) 设计用户体验 (UX) 设计是设计和开发数字产品,如网站和应用程序,为用户提供一个无缝和愉快的体验。它包含了获得和纳...详情>>
2023-10-11 10:02:10
k-means方法存在的主要缺点是什么以及如何解决?
一、k-means方法缺点1.K值的选取不好把握;2.对于不是凸的数据集比较难收敛;3.如果各隐含类别的数据不平衡,比如各隐含类别的数据量严重失衡,...详情>>
2023-10-11 06:54:05