上一页 1 ··· 34 35 36 37 38 39 40 41 42 ··· 53 下一页
摘要: 示例:模拟远程过程调用(RPC) 服务器开发中会使用 RPC(Remote Procedure Call,远程过程调用)简化进程间通信的过程。RPC 能有效低封装通信过程,让远程的数据收发通信过程看起来就像本地的函数调用一样。 本例中,使用通道替代 Socket 实现 RPC 的过程。客户端与服务器 阅读全文
posted @ 2022-05-11 13:14 左扬 阅读(138) 评论(0) 推荐(0) 编辑
摘要: 通道的多路复用——同时处理接收和发送多个通道的数据 多路复用是通信和网络中的一个专业术语。多路复用通常表示一个信道上传输多路信号和数据流的过程和技术。 在使用通道时,想同时接收多个通道的数据是一件困难的事情。通道在接收数据时,如果没有数据可以接收将会发生阻塞。虽然可以使用如下模式进行遍历,但运行性能 阅读全文
posted @ 2022-05-11 12:41 左扬 阅读(363) 评论(0) 推荐(0) 编辑
摘要: 带缓冲的通道 在无缓冲通道的基础上,为通道增加一个有限大小的存储空间形成带缓冲通道。 带缓冲通道在发送时无需等待接收方接收即可完成发送过程,并且不会发生阻塞,只有当存储空间满时,才会发生阻塞。 带缓冲通道有数据时,接收方将不会发生阻塞,直到通道中没有数据可读时,通道将会再读阻塞。 1、创建带缓冲通道 阅读全文
posted @ 2022-05-11 12:15 左扬 阅读(214) 评论(0) 推荐(0) 编辑
摘要: 单向通道——通道中的单行道 Go 的通道可以在声明时约束其操作方向,如只发送或是只接收。这种约束方向的通道被称为单向通道。 1、单向通道的声明格式 var 通道实例 chan<- 元素类型 // 只能发送通道 var 通道实例 <-chan 元素类型 // 只能接收通道 元素类型:通道包含的元素类型 阅读全文
posted @ 2022-05-11 12:11 左扬 阅读(198) 评论(0) 推荐(0) 编辑
摘要: 并发打印 使用无缓冲通道往里面装入数据时,装入方将被阻塞,直到另外通道在另外一个 goroutine 中被取出。同样,如果通道中没有放入任何数据,接收方试图从通道中获取数据时,同样被阻塞。发送和接收的操作是同步完成的。 package main import "fmt" func printer(c 阅读全文
posted @ 2022-05-11 11:47 左扬 阅读(69) 评论(0) 推荐(0) 编辑
摘要: 在多个 goroutine 间通信的管道——通道(Channel) 单纯地将函数并发执行是没有意义的。函数与函数间需要交换数据才能体现并发执行函数的意义。 虽然可以使用共享内存进行数据交换,但是共享内存在不同的 goroutine 中容易发生竟态问题。为了保证数据交换的正确性,必须使用互斥量对内存进 阅读全文
posted @ 2022-05-11 00:10 左扬 阅读(446) 评论(0) 推荐(0) 编辑
摘要: 调整并发的运行性能(GOMAXPROCS) 在 Go 运行时(runtime)实现了一个小型的任务调度器。这套调度器的工作原理类似操作系统调度线程,Go 程序调度器可以高效地将 CPU 资源分配给每一个任务。传统逻辑中,开发者需要维护 线程池中线程 与 CPU 核心数量的对应关系。同样的,Go 中也 阅读全文
posted @ 2022-05-11 00:03 左扬 阅读(409) 评论(0) 推荐(0) 编辑
摘要: 使用匿名函数创建 goroutine go 关键字后也可以为匿名函数或闭包启动 goroutine。 一、使用匿名函数创建 goroutine 的方式 使用匿名函数或闭包创建 goroutine 时,除了将函数定义部分写在 go 的后面之外,还需要加上匿名函数的调用参数,格式如下: go runc( 阅读全文
posted @ 2022-05-10 23:53 左扬 阅读(186) 评论(0) 推荐(0) 编辑
摘要: 轻量级线程(goroutine)——根据需要随时创建的“线程” 一、什么是 goroutine? 在编写 Socket 网络程序时,需要提前准备一个线程池为每一个 Socket 的收发包分配一个线程。开发人员需要为 线程数量 和 CPU 间建立一个对应关系,以保证每个任务能及时地分配到 CPU 上进 阅读全文
posted @ 2022-05-10 23:24 左扬 阅读(187) 评论(0) 推荐(0) 编辑
摘要: 并发和并行 并发和并行区别。 并发(concurrency):把任务在不同的时间点交给处理器进行处理。在同一时间点,任务并不会同时运行。 并行(parallelism):把每一个任务分配给每一个处理器独立完成。在同一时间点,任务一定是同时运行。 Go 语言通过编译器运行时(runtime),在语言上 阅读全文
posted @ 2022-05-10 23:12 左扬 阅读(50) 评论(0) 推荐(0) 编辑
上一页 1 ··· 34 35 36 37 38 39 40 41 42 ··· 53 下一页
levels of contents