当前位置: 首页 > news >正文

Golang笔记_day10

Go面试题(三)

1、什么是channel,为什么它可以做到线程安全

     在Go语言中,channel是一种类型,它可以用来在协程之间传递数据
通过共享内存来通信:

        通过共享内存来通信是指多个线程或进程直接访问相同的内存区域,它们通过读写这个共享内存区域来进行数据传递和通信。在这种模式下,各个线程或进程之间可以直接修改共享内存中的数据,实现数据的共享和传递。然而,这种方式需要开发者自行处理数据同步和互斥访问的问题,以避免数据竞争和一致性问题。
通过通信来共享内存:

        通过通信来共享内存是指使用消息传递等通信方式,在不同的线程或进程之间进行数据交换和共享。在这种模式下,各个线程或进程之间并不直接访问共享内存,而是通过发送消息、使用通道等方式来进行数据交换。这种方式可以避免直接操作共享内存带来的数据竞争和一致性问题,通过通信进行数据共享更加安全可靠,也更容易实现并发编程中的数据同步和通信需求。
为什么channel是线程安全的
      Golang的Channel,发送一个数据到Channel 和 从Channel接收一个数据都是原子性的。核心思想就是:通过通信来共享内存。

内置同步机制:

        Channel 在底层实现时使用了锁和其他同步机制来保证并发读写的安全性。
        在向通道发送或接收数据时,会自动进行加锁和解锁操作,确保每次操作的原子性和线程安全性。
阻塞特性:

        当通道满了(发送者发送数据时),发送操作会阻塞直到有其他 goroutine 从通道中接收数据。
当通道为空(接收者尝试接收数据时),接收操作会阻塞直到有其他 goroutine 向通道中发送数据。
        这种阻塞特性可以有效避免并发读写冲突,保证了数据操作的线程安全性。
单个 goroutine 拥有所有权:

        Go 语言的设计理念是通过通信来共享内存,而不是通过共享内存来通信。
每个通道只能被一个 goroutine 拥有,并且在同一时间只能由一个 goroutine 发送或接收数据,这种所有权机制确保了通道的线程安全性。

2、怎么限制Goroutine的数量

        goroutine数量太多了,往往会带来很多麻烦,比如耗尽系统资源导致程序崩溃,或者CPU使用率过高导致系统忙不过来

控制goroutine的方法

        Context

        channel

控制goroutine的数量

        协程池

        信号量Semaphore

    channel+waitgroup实现

3、Channel是同步的还是异步的

        Go语言中的channel可以是异步也可以是同步,这取决与它是否是一个缓冲的channel

同步channel
        无缓冲的channel默认是同步的channel类型,即创建时没有执行缓冲大小。当数据被发送到无缓冲的channel中时,发送者会阻塞直到接受者收到数据。同样,当从无缓冲的channel中接收数据的时候,接受者会阻塞直到发送者发送数据。这种机制允许两个goroutine进行同步的通信。

异步的channel
        有缓冲的channel是异步的,它拥有一个缓冲队列,创建channel的时候指定队列的大小。发送者向有缓冲的channel发送数据的时候,如果缓冲区未满,则发送就不会阻塞,否则发送者同样会阻塞直到有接受者接收到数据。同样,接收者从有缓冲区的channel接收数据时,如果缓冲中有数据,则接收就不会阻塞,否则接收者会阻塞直到缓冲区有发送者发送数据。

http://www.lryc.cn/news/466640.html

相关文章:

  • mlir learn
  • Windows安装RabbitMQ 4.0.2(图文教程)
  • 分布式系统中为什么需要使用消息队列
  • Linux环境配置(学生适用)
  • 麦禾软件:Mac用户找免费开源工具的最佳选择
  • OpenCV4.8 开发实战系列专栏之 08 - 通道分离与合并
  • iOS 18.1 RC 版本发布,修复iPhone16随机重启、浏览视频卡顿等bug
  • 安装buildkit,并使用buildkit构建containerd镜像
  • maven jar包二进制文件 invalid stream header: EFBFBDEF 的错误
  • Git绑定Gitee或Github以及Git面试常见题
  • 值得细读的8个视觉大模型生成式预训练方法
  • go 包相关知识
  • 机器学习:opencv--人脸检测以及微笑检测
  • linux系统挂载硬盘
  • MySQL实现主从同步
  • 人工智能--数学基础
  • 2024人工智能技术的普及 如何看待AI技术的应用前景
  • 日常记录:springboot 2.2.5 + es 6.8.12
  • MySQL数据库备份与恢复详解
  • 10.22 MySQL
  • 「AIGC」n8n AI Agent开源的工作流自动化工具
  • Android 中获取和读取短信验证码
  • SQL语句高级查询(适用于新手)
  • main.ts中引入App.vue报错,提示“Cannot find module ‘./App.vue’ or its corresponding type
  • Android15音频进阶之组音量调试(九十)
  • 【Java】常用方法合集
  • 深入了解Vue Router:基本用法、重定向、动态路由与路由守卫的性能优化
  • 深入理解InnoDB底层原理:从数据结构到逻辑架构
  • Linux介绍及操作命令
  • JS | 详解图片懒加载的6种实现方案