Golang面试系列2-协程调度GMP

1. 典型线程池缺陷

线程池结构

处理流程

        线程池中的worker线程不断地从任务队列中取出任务G并执行,而worker线程的调度会交由操作系统。

缺陷分析

  • Worker线程执行的G任务中发生系统调用,操作系统会将该Worker线程阻塞,意味着消费任务队列的可用worker线程变少---线程池消费任务队列的能力变弱
  • Worker线程执行的大部分任务G发生系统调用---任务队列中会产生任务堆积
  • 虽然可以通过增加线程池的worker线程数来改善以上,但是CPU数量有限,随着线程数量增加,线程争抢CPU和线程频繁切换问题加剧,产生性能瓶颈

2. Goroutine调度器

说明:Go提供的一种调度机制,可以在线程中实现协程(Goroutine)的调度,上下文切换更轻量

2.1 Go的协程和线程有哪些区别?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值