Golang随笔之《Go专家编程》查漏补缺

简介: Golang随笔之《Go专家编程》查漏补缺

第一章 常见数据结构的实现原理

管道

普通使用场景

  1. 读写nil管道均会阻塞,而且是永久阻塞
  2. 关闭的管道仍然可以读取数据
  3. 向关闭的管道写数据会触发panic

v, ok := <-ch的ok含义

package main
import "fmt"
func main() {
  ch := make(chan int, 2)
  ch <- 6
  ch <- 8
  close(ch)
  for i := 0; ; i++ {
    v, ok := <-ch
    if ok {
      fmt.Println("第", i, "第读取成功,value=", v, "ok=true")
    } else {
      fmt.Println("第", i, "第读取失败,", "ok=false")
      break
    }
  }
}


第 0 第读取成功,value= 6 ok=true
第 1 第读取成功,value= 8 ok=true
第 2 第读取失败, ok=false

v, ok := <-ch

第一个变量表示读出的数据,第二个变量bool类型,表示是否成功读取了数据,需要注意的是,第二个变量不用于指示管道关闭的状态!—需要注意的是,第二个变量不用于指示管道关闭的状态

管道已关闭但是缓冲区中仍有数据,那么管道读取表达返回的第一个变量为读取到的数据,第二个变量为true。可以看到,只有管道已关闭且缓冲区中没有数据时,管道读取表达式返回的第二个变量才跟关闭状态一致。

读写channel底层逻辑图例

向管道写数据在时在实现有一个小技巧,当接收队列recvq不为空时,说明缓冲区中没有数但是有协程在等待数据,此时会把数据直接传递给recvq队列中的第一个协程,而不必再写入缓冲区

类似的,如果等待发送队列sendq不为空,且没有缓冲区,那么此时将直接从sendq队列的第一个协程中获取数据

slice

简单表达式:

  • b:=a[low:height]
  • len(b)=height-low
  • cap(b)=cap(a)-low

扩展表达式:

  • b:=a[low:height:max]
  • len(b)=height-low
  • cap(b)=max-low

解释

在使用简单表达式的时候,用append函数增加新的元素时,可能会覆盖之前切片的元素,所以我们需要一种限制新切片容量的表达式,即扩展表达式,我们称扩展表达式为被封印的切片,当使用append函数向被封印的切片追加新元素时,如果容量不足则会产生一个全新的切片,而不会覆盖原始的数组或切片

ota

本质

iota代表了const声明块的行索引,从0开始

特点:如果为常量指定了一个表达式,但后续的常量没有表达式,则会继续上面的表达式

string

双引号和反单引号的区别

hi

this is wxf

使用双引号表达时,需要对特殊字符转义

s:="hi,\nthis is \"wxf\""

使用反单引号时,不需要对特殊字符转义

s:=`hi,
this is wxf`

string的注意点

  1. string可能为空,但不会是nil
  2. 字符串拼接时会触发内存分配以及内存拷贝(s=s+“wxf”)
  3. 无论是string转[]byte还是[]byte转string,都会发生一次内存拷贝,会有一定的开销
  4. 字符串的长度是指字节数,而非字符数

第二章 控制结构

select

复习点

直接看一遍之前的博文即可,书上的不是很详细

Golang底层原理剖析之多路select、channel数据结构和阻塞与非阻塞

for-range

range不同类型的区别

  • channel:遇到nil的channel会永久阻塞
  • slice:遍历slice或者array时已经决定了循环次数,append也没事,新添加的数据不会被遍历到
  • map:遍历map时不要添加或者删除元素,会发生不可遇到的情况
  • channel:range通道时,只有当close(ch)后,遍历完了range才会自动退出,如果没有close,那么就阻
目录
相关文章
|
2月前
|
监控 算法 Go
Golang深入浅出之-Go语言中的服务熔断、降级与限流策略
【5月更文挑战第4天】本文探讨了分布式系统中保障稳定性的重要策略:服务熔断、降级和限流。服务熔断通过快速失败和暂停故障服务调用来保护系统;服务降级在压力大时提供有限功能以保持整体可用性;限流控制访问频率,防止过载。文中列举了常见问题、解决方案,并提供了Go语言实现示例。合理应用这些策略能增强系统韧性和可用性。
126 0
|
18天前
|
Go
The “gopls“ command is not available. Run “go get -v golang.org/x/tools/gopls“ to install.【已解决】
The “gopls“ command is not available. Run “go get -v golang.org/x/tools/gopls“ to install.【已解决】
11 3
|
18天前
|
Go
【golang】Go 判断字符串是否包含指定字符
【golang】Go 判断字符串是否包含指定字符
12 1
|
2月前
|
前端开发 Go
Golang深入浅出之-Go语言中的异步编程与Future/Promise模式
【5月更文挑战第3天】Go语言通过goroutines和channels实现异步编程,虽无内置Future/Promise,但可借助其特性模拟。本文探讨了如何使用channel实现Future模式,提供了异步获取URL内容长度的示例,并警示了Channel泄漏、错误处理和并发控制等常见问题。为避免这些问题,建议显式关闭channel、使用context.Context、并发控制机制及有效传播错误。理解并应用这些技巧能提升Go语言异步编程的效率和健壮性。
73 5
Golang深入浅出之-Go语言中的异步编程与Future/Promise模式
|
2月前
|
Prometheus 监控 Cloud Native
Golang深入浅出之-Go语言中的分布式追踪与监控系统集成
【5月更文挑战第4天】本文探讨了Go语言中分布式追踪与监控的重要性,包括追踪的三个核心组件和监控系统集成。常见问题有追踪数据丢失、性能开销和监控指标不当。解决策略涉及使用OpenTracing或OpenTelemetry协议、采样策略以及聚焦关键指标。文中提供了OpenTelemetry和Prometheus的Go代码示例,强调全面可观测性对微服务架构的意义,并提示选择合适工具和策略以确保系统稳定高效。
170 5
|
2月前
|
负载均衡 算法 Go
Golang深入浅出之-Go语言中的服务注册与发现机制
【5月更文挑战第4天】本文探讨了Go语言中服务注册与发现的关键原理和实践,包括服务注册、心跳机制、一致性问题和负载均衡策略。示例代码演示了使用Consul进行服务注册和客户端发现服务的实现。在实际应用中,需要解决心跳失效、注册信息一致性和服务负载均衡等问题,以确保微服务架构的稳定性和效率。
37 3
|
2月前
|
分布式计算 Java Go
Golang深入浅出之-Go语言中的分布式计算框架Apache Beam
【5月更文挑战第6天】Apache Beam是一个统一的编程模型,适用于批处理和流处理,主要支持Java和Python,但也提供实验性的Go SDK。Go SDK的基本概念包括`PTransform`、`PCollection`和`Pipeline`。在使用中,需注意类型转换、窗口和触发器配置、资源管理和错误处理。尽管Go SDK文档有限,生态系统尚不成熟,且性能可能不高,但它仍为分布式计算提供了可移植的解决方案。通过理解和掌握Beam模型,开发者能编写高效的数据处理程序。
166 1
|
2月前
|
缓存 测试技术 持续交付
Golang深入浅出之-Go语言中的持续集成与持续部署(CI/CD)
【5月更文挑战第5天】本文介绍了Go语言项目中的CI/CD实践,包括持续集成与持续部署的基础知识,常见问题及解决策略。测试覆盖不足、版本不一致和构建时间过长是主要问题,可通过全面测试、统一依赖管理和利用缓存优化。文中还提供了使用GitHub Actions进行自动化测试和部署的示例,强调了持续优化CI/CD流程以适应项目需求的重要性。
73 1
|
2月前
|
Kubernetes Cloud Native Go
Golang深入浅出之-Go语言中的云原生开发:Kubernetes与Docker
【5月更文挑战第5天】本文探讨了Go语言在云原生开发中的应用,特别是在Kubernetes和Docker中的使用。Docker利用Go语言的性能和跨平台能力编写Dockerfile和构建镜像。Kubernetes,主要由Go语言编写,提供了方便的客户端库与集群交互。文章列举了Dockerfile编写、Kubernetes资源定义和服务发现的常见问题及解决方案,并给出了Go语言构建Docker镜像和与Kubernetes交互的代码示例。通过掌握这些技巧,开发者能更高效地进行云原生应用开发。
88 1
|
2月前
|
负载均衡 监控 Go
Golang深入浅出之-Go语言中的服务网格(Service Mesh)原理与应用
【5月更文挑战第5天】服务网格是处理服务间通信的基础设施层,常由数据平面(代理,如Envoy)和控制平面(管理配置)组成。本文讨论了服务发现、负载均衡和追踪等常见问题及其解决方案,并展示了使用Go语言实现Envoy sidecar配置的例子,强调Go语言在构建服务网格中的优势。服务网格能提升微服务的管理和可观测性,正确应对问题能构建更健壮的分布式系统。
41 1