😥 整理不易,此资源只针对正式星主开放,
还请入驻星球后再来观看。

GOLANG ROADMAP

阅读模式

  • 沉浸
  • 自动
  • 日常
首页
Go学习
  • Go学院

    • Go小课
    • Go小考
    • Go实战
    • 精品课
  • Go宝典

    • 在线宝典
    • B站精选
    • 推荐图书
    • 精品博文
  • Go开源

    • Go仓库
    • Go月刊
  • Go下载

    • 视频资源
    • 文档资源
Go求职
  • 求职服务

    • 内推互助
    • 求职助力
  • 求职刷题

    • 企业题库
    • 面试宝典
    • 求职面经
Go友会
  • 城市
  • 校园
推广返利 🤑
实验区
  • Go周边
消息
更多
  • 用户中心

    • 我的信息
    • 推广返利
  • 玩转星球

    • 星球介绍
    • 角色体系
    • 星主权益
  • 支持与服务

    • 联系星主
    • 成长记录
    • 常见问题
    • 吐槽专区
  • 合作交流

    • 渠道合作
    • 课程入驻
    • 友情链接
author-avatar

GOLANG ROADMAP


首页
Go学习
  • Go学院

    • Go小课
    • Go小考
    • Go实战
    • 精品课
  • Go宝典

    • 在线宝典
    • B站精选
    • 推荐图书
    • 精品博文
  • Go开源

    • Go仓库
    • Go月刊
  • Go下载

    • 视频资源
    • 文档资源
Go求职
  • 求职服务

    • 内推互助
    • 求职助力
  • 求职刷题

    • 企业题库
    • 面试宝典
    • 求职面经
Go友会
  • 城市
  • 校园
推广返利 🤑
实验区
  • Go周边
消息
更多
  • 用户中心

    • 我的信息
    • 推广返利
  • 玩转星球

    • 星球介绍
    • 角色体系
    • 星主权益
  • 支持与服务

    • 联系星主
    • 成长记录
    • 常见问题
    • 吐槽专区
  • 合作交流

    • 渠道合作
    • 课程入驻
    • 友情链接
  • Go真实面试题汇总系列

    • Go基础篇
  • 宝典内容

    • 76. runtime提供常见的方法
    • 90. golang支持哪些并发机制
    • 97. go并发机制
    • 101. go语言怎么做的连接复用,怎么支持的并发请求,go的netpoll是怎么实现的像阻塞read一样去使用底层的非阻塞read
    • 107. go用共享内存的方式实现并发如何保证安全?
    • 115. 讲一讲 Golang 的并发控制
    • 178. golang中Context的使用场景
    • 179. context 的数据结构
    • 190. Golang 怎么在并发编程中等待多个 goroutine 结束?
    • 275. schedulerc的实现细节
    • 283. 说一下reflect
    • 284. 有很多sync_recv状态是发生了什么
    • 302. go实现一个并发限制爬虫
    • 310. 两个协程交替打印一个数组,使数组中的数据按顺序输出
    • 313. 一组协程完成后需要通知其他协程,可以怎么办?
    • 317. 从运行速度来讲,go的并发模型channel和goroutine
    • 319. sync.Once如何实现线程安全
    • 326. go 同步、channel的实现
    • 333. golang怎么协调并发协程的调度
    • 337. 介绍一下 Go 的 context
    • 352. 如何实现只开100个协程
    • 365. 有生产者和消费者应该在哪里关闭通道?
    • 381. golang除了goroutine还有什么处理并发的方法
    • 384. 给定n个并发量,并发处理数组
    • 404. context上下文控制
    • 409. go 多协程怎么同步
    • 413. go 怎么控制查询timeout (context)
    • 419. 怎么理解“不要用共享内存来通信,而是用通信来共享内存”
    • 439. Context 包的实现
    • 445. 协程间通信
    • 450. 写个channel相关的题,并发模型,爬虫url,控制并发量
    • 457. Go 并发优秀在哪里,需要通过实际的测试,benchmark等说明
    • 462. Go 高并发的特点
    • 469. go waitgroup 的坑

😥 整理不易,此资源只针对正式星主开放,
还请入驻星球后再来观看。

462. Go 高并发的特点


企业题库解析小组

题目序号:6748 题目来源:360 频次:2

答案:苏木

Go 语言天生支持高并发,得益于 go 关键字开辟了协程的调用。

func main()  {
   go add(1,1)  // 开辟了协程
   go add(2,2)  // 开辟了协程
   time.Sleep(time.Second)
}
func add(a int,b int)  {
   result := a+b
   fmt.Println(result)
}
1
2
3
4
5
6
7
8
9

协程: 英文叫作 Coroutine,协程是一种用户态的轻量级线程。协程拥有自己的上下文和栈,协程调度切换的时候,将寄存器上下文和栈保存下来,在切回来的时候,又恢复之前保存的上下文和栈。在 go 语言中的协程实体就是 goroutine。

Go 的并发

Go 语言参考 Communicating Sequential Process(CSP) 模型设计了 goroutine。同时, Go 在 CSP 的 channel 基础中又加入了缓存机制,可以使得当前的任务暂存起来(CSP 中的 channel 是立刻执行),等待执行进程准备好了,即接收到 channel,再逐个按顺序执行。

  1. goroutine: go 执行并发的实体,它底层是使用协程(coroutine)实现并发,coroutine 是一种运行在用户态的用户线程,go 底层选择使用 coroutine 的出发点是因为,它具有以下特点:

    • 用户空间 避免了内核态和用户态的切换导致的成本
    • 可以由语言和框架层进行调度
    • 更小的栈空间允许创建大量的实例 2) channel: 被单独创建并且可以在进程之间传递,它的通信模式类似于 boss-worker 模式的,一个实体通过将消息发送到 channel 中,然后又监听这个 channel 的实体处理,两个实体之间是匿名的,这个就实现实体中间的解耦,在实现原理上其实是一个阻塞的消息队列。 3) 调度器: goroutine 中提供了调度器,在调度器加入了steal working 算法 ,goroutine 是可以被异步抢占,因此没有函数调用的进程不再对调度器造成死锁或造成垃圾回收的大幅变慢。并且 go 对网络IO库进行了封装,屏蔽了复杂的细节,对外提供统一的语法关键字支持,简化了并发程序编写的成本。

参考资料

Go语言的并发编程 https://www.csdn.net/tags/NtDaYg0sMDMwNjAtYmxvZwO0O0OO0O0O.html

https://blog.csdn.net/big_white_py/article/details/111465167