首页
技术小册
AIGC
面试刷题
技术文章
MAGENTO
云计算
视频课程
源码下载
PDF书籍
「涨薪秘籍」
登录
注册
Go 中的 = 和 := 有什么区别?
Go 中的指针的意义是什么?
Go 多值返回有什么用?
Go 有异常类型吗?
Go 中的 rune 和 byte 有什么区别?
Go 语言中的深拷贝和浅拷贝?
什么叫字面量和组合字面量?
对象选择器自动解引用怎么用?
map 的值不可寻址,那如何修改值的属性?
有类型常量和无类型常量的区别?
为什么传参使用切片而不使用数组?
Go 语言中 hot path 有什么用呢?
引用类型与指针,有什么不同?
Go 是值传递,还是引用传递、指针传递?
Go中哪些是可寻址,哪些是不可寻址的?
slice 扩容后容量及内存如何计算?
goroutine 存在的意义是什么?
说说 Go 中闭包的底层原理?
defer 的变量快照什么情况会失效?
说说你对 Go 里的抢占式调度的理解。
简述一下 Go 栈空间的扩容/缩容过程?
说一下 GMP 模型的原理。
GMP 模型为什么要有 P ?
不分配内存的指针类型能用吗?
如何让在强制转换类型时不发生内存拷贝?
Go 中的 GC 演变是怎样的?
Go 中哪些动作会触发 runtime 调度?
有哪些情况会导致协程泄露?
局部变量分配在栈上还是堆上?
为什么常量、字符串和字典不可寻址?
为什么 slice 元素是可寻址的?
Go 的默认栈大小是多少?最大值多少?
Go 中的分段栈和连续栈的区别?
内存对齐、内存布局是怎么回事?
Go 里是怎么比较相等与否?
所有的 T 类型都有 *T 类型吗?
数组对比切片有哪些优势?
GMP 偷取 G 为什么不需要加锁?
堆引用栈内存是怎么回收的?
当前位置:
首页>>
技术小册>>
GO面试指南
小册名称:GO面试指南
在 Go 中,有一些操作会触发 runtime 调度,包括: - 阻塞操作:比如通道的读写、休眠、等待 I/O 完成等。 - GC:当 Go 运行时需要回收垃圾时,也会触发调度器的运行。 - 系统调用:因为 Go 运行时在底层使用了线程和协程,所以当系统调用需要等待 I/O 操作完成时,调度器会将当前线程放入等待队列,然后切换到另一个线程上继续执行。 - 用户调用 runtime.Gosched() 函数:这个函数可以手动触发调度器的运行,让当前 goroutine 主动让出 CPU 给其他 goroutine 使用。 下面是一个示例代码,演示了阻塞操作和手动调用 runtime.Gosched() 函数会触发调度器的运行: ``` package main import ( "fmt" "time" ) func main() { go func() { for i := 0; i < 10; i++ { fmt.Println("goroutine 1:", i) time.Sleep(100 * time.Millisecond) // 阻塞操作 } }() go func() { for i := 0; i < 10; i++ { fmt.Println("goroutine 2:", i) time.Sleep(100 * time.Millisecond) // 阻塞操作 } }() for i := 0; i < 10; i++ { fmt.Println("main goroutine:", i) if i == 5 { runtime.Gosched() // 手动触发调度器运行 } } } ``` 在这个示例代码中,我们启动了两个 goroutine,每个 goroutine 都会执行一段循环并进行阻塞操作。同时,主 goroutine 也会执行一段循环,并在第 5 次迭代时手动调用 runtime.Gosched() 函数。 由于每个 goroutine 的循环都进行了阻塞操作,所以它们会在运行一段时间后自动让出 CPU 给其他 goroutine 使用。 另外,当主 goroutine 调用了 runtime.Gosched() 函数时,它也会主动让出 CPU 给其他 goroutine 使用。这些操作都会触发调度器的运行,让所有 goroutine 在执行过程中公平地分享 CPU 时间。
上一篇:
Go 中的 GC 演变是怎样的?
下一篇:
有哪些情况会导致协程泄露?
该分类下的相关小册推荐:
Go进阶之分布式爬虫实战
深入浅出Go语言核心编程(五)
Go开发基础入门
深入解析go语言
go编程权威指南(一)
Go开发权威指南(上)
Go 组件设计与实现
深入浅出Go语言核心编程(七)
深入浅出Go语言核心编程(二)
Golang并发编程实战
WebRTC音视频开发实战
深入浅出Go语言核心编程(八)