了解docker就不得不学习一下go语言了。尤其是接口一类的,感觉不是很方便。一点点更新自己的理解吧。
1.go语言中的package。
在java中直接是类的感念,import也是直接对类生效的。但是在go语言中目录和包都会有相应的使用。
目录: import的就是导入的目录。
packege:一个目录下可以有多个go文件,但是只能有一个目录。
另外,系统默认的package是有指定路径的。@GOPATH/src,导入的包都是从这个路径开始的。看源码的时候还是要注意点的,不然编译器都识别不出来
import "fmt" //go语言自带的包
fmt.Print() //使用方式
import "google.golang.org/grpc"
grpc.NewServer() //有时候看第三方的源码的时候就很不方便,只能全局搜索。
pb "xcl" //给目录下的包起个别名
pb.UserStatus_ONLINE
2.简单的语法,只备注一下,有些东西还是类似于C++,有些又类似于python。注意一点,go语言中,导入的包不用,也是会变易出错的
定义:
var str string
var str := "hello"
方法:
// func 关键字
// 紧接着属于某个定义的结构体的方法
// 方法名
// 参数列表
// 返回值,都是相反的,感觉还是很别扭的
func (s *server) Logout(ctx context.Context, uid *pb.UserID) (*pb.FuncResponse, error) {
return param1, param2
}
结构体:
类似于C语言吧,还有指针的概念。
type server struct{}
3.go get 可以下载安装远程的代码库,默认下载在@GOPATH/src目录下。
go get google.golang.org/grpc
export PATH=$PATH:$GOPATH/bin //下载的第三方二进制文件,会默认在这个目录,使用的时候添加一下环境变量。
4.goroutine的使用
go 语言的一个很大的优势就是可以方便地编写并发程序。go 语言内置了 goroutine 机制。但是协程会因为main函数的结束而结束。
实现方式
func test(){
fmt.Println("hello world")
}
go test() //使用go关键字来创建一个goroutine,类似于线程的使用
5.goroutine由于不能阻塞主线程,可以结合channel使用。管道是Go语言在语言级别上提供的goroutine间的通讯方式,我们可以使用channel在多个goroutine之间传递消息。channel是进程内的通讯方式,是不支持跨进程通信的,如果需要进程间通讯的话,可以使用Socket等网络方式。
package main
import "fmt"
func print(ch chan int) {
fmt.Println("Hello world")
ch<- 1
}
func main() {
chs := make([]chan int, 10) //创建一个通道数组
for i := 0; i < 10; i++ {
chs[i] = make(chan int)
go print(chs[i])
}
for _, ch := range(chs){
<-ch //如果读不到数据会阻塞
}
}
参考:
[1] go语言入门
[2] Go语言中的管道(Channel)总结
[3] 对于golang的goroutine并发处理任务时的理解
有疑问加站长微信联系(非本文作者)