多线程 – 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

相关文章

ArrayList简介:ArrayList 的底层是数组队列,相当于动态数组。与 Java 中的数组相比,它的容量能动态增...
一、进程与线程 进程:是代码在数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位。 线程...
本文为博客园作者所写: 一寸HUI,个人博客地址:https://www.cnblogs.com/zsql/ 简单的一个类...
#############java面向对象详解#############1、面向对象基本概念2、类与对象3、类和对象的定义格式4、...
一、什么是异常? 异常就是有异于常态,和正常情况不一样,有错误出错。在java中,阻止当前方法或作用域...
Collection接口 Collection接口 Collection接口 Collection是最基本的集合接口,一个Collection代表一组...