微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

多线程 – Golang阻塞和非阻塞

我对于如何处理非阻塞IO有点困惑.
API主要看起来与我同步,在观看Go上的演示文稿时,听到诸如“和通话块”这样的意见并不罕见.

在从文件或网络读取文件时,Go会使用阻止IO吗?
或者在Go程序中使用时,是否有某种重现代码的魔法?

来自C#背景,这感觉非常不直观,在C#中,在使用async API时,我们有一个等待关键字.
其中清楚地表明API可以产生当前线程并在继续之后继续继续.

所以TLDR;
在Go程序中执行IO时,会阻止当前线程,还是将其转换为C#,如异步等待状态机使用延续?

解决方法

Go有一个调度程序,可以让您编写同步代码,并自行进行上下文切换,并使用异步IO.所以,如果你运行几个goroutine,他们可能运行在一个单一的系统线程,当你的代码阻止从goroutine的视图,它不是真的阻止.这不是魔术,但是,它掩盖了你的所有这些东西.

调度程序将在需要时分配系统线程,并且在真正阻止的操作期间(我认为文件IO例如阻塞或调用C代码).但是,如果您正在做一些简单的http服务器,您可以使用几千个“真正的线程”来实现几千个goroutine.

您可以阅读更多关于Go的内部工作:

https://morsmachine.dk/go-scheduler

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


应用场景 C端用户提交工单、工单创建完成之后、会发布一条工单创建完成的消息事件(异步消息)、MQ消费者收到消息之后、会通知各处理器处理该消息、各处理器处理完后都会发布一条将该工单写入搜索引擎的消息、最终该工单出现在搜索引擎、被工单处理人检索和处理。 事故异常体现 1、异常体现 从工单的流转记录发现、
线程类,设置有一个公共资源 package cn.org.chris.concurrent; import java.util.concurrent.locks.Lock; import java.util.concurrent.locks.ReentrantLock; /** * @Descrip
Java中的数字(带有0前缀和字符串)
在Java 9中使用JLink的目的是什么?
Java Stream API Filter(过滤器)
在Java中找到正数和负数数组元素的数量
Java 9中JShell中的不同启动脚本是什么?
使用Java的位填充错误检测技术
java中string是什么
如何使用Java中的JSON-lib API将Map转换为JSON对象?