GO基础记录

  • defer:生命周期结束后执行(栈顺序),在打开一些资源后,可以使用defer执行关闭.释放的操作,类似RAII
  • panic:类似于throw,抛出异常
  • make()用于构建切片,map,channel

defer,panic,recover配合使用代码

go 复制代码
defer func(){
    if ret := recover(); ret != nil{
        fmt.print(ret)
    }
}

panic("error")
  • interface:接口类型,只需定义接口然后实现接口,无需绑定,即可使用多态
  • interface{}:相当于any类型,可装万物
go 复制代码
type duck interface{
    gaga()
    walk()
}

type pskDuck struct{
    age int
}

type (p *pskDuck) gaga(){
    
}
type (p *pskDuck) walk(){
    
}

func main(){
    var value duck = &pskDuck{}
    d.gaga()
}
  • go在同一级目录下包名要一致,import的路径是相对于*.mod文件的路径

  • 小驼峰相当于private,大驼峰相当于public(针对于不同的包之间)

  • 在import文件前面可以声明包的别名

    • import std "fmt",从此fmt包要写成std
    • 在前面加.就类似于using namespace,不在需要通过包名使用(少使用,可能重名,污染)
    • 如果引入包,但是不使用,是会报错的,需要在前面添加_(import一个包会默认调用func init()函数,这是使用场景)
  • go get指令可以安装库,自动安装依赖

  • go mod init xxx初始化

  • go mod tidy添加需要用到但go.mod中查不到的模块,删除未使用的模块(推荐)

  • sync.WaitGroup:主要用于goroutine的执行等待

    • add用于添加等待的次数
    • done用于减少一次计数器
    • Wait阻塞等待
  • go关键字启动一个协程

  • atomic是一个原子包,里面提供了很多原子方法

  • channel分为有缓冲和无缓冲,如果需要使用无缓冲(make(chan string,0)),那么需要启动一个goroutine去读取

  • 可以通过close函数关闭一个channel,已经关闭的channel不能在放值,但是可以取值,

  • 可以通过for range不断地取值

    • <-chan只读channel

    • chan<-只写channel

    go 复制代码
      c := make(chan int,3)
      var send chan<- int = c
      var read <-chan int = c
      
  • go实现继承需要以匿名的形式嵌入结构体

    go 复制代码
    struct A{}
    struct B{
        A
    }
相关推荐
FleetingLore几秒前
C C51 | 按键的单击、双击和长按的按键动作检测
后端
丸码26 分钟前
Java异常体系全解析
java·开发语言
v***885627 分钟前
Springboot项目:使用MockMvc测试get和post接口(含单个和多个请求参数场景)
java·spring boot·后端
q***721928 分钟前
PHP使用Redis实战实录2:Redis扩展方法和PHP连接Redis的多种方案
开发语言·redis·php
k***825133 分钟前
python爬虫——爬取全年天气数据并做可视化分析
开发语言·爬虫·python
IMPYLH33 分钟前
Lua 的 require 函数
java·开发语言·笔记·后端·junit·lua
曾经的三心草35 分钟前
基于正倒排索引的Java文档搜索引擎1-实现索引模块-实现Parser类
java·开发语言·搜索引擎
爱找乐子的李寻欢1 小时前
线上批量导出 1000 个文件触发 OOM?扒开代码看本质,我是这样根治的
后端
q***01651 小时前
Python爬虫完整代码拿走不谢
开发语言·爬虫·python
顺心而行...1 小时前
一些问题记录
开发语言