1.https://dl.gocn.io/ (国内下载地址)

  

 

2.https://golang.org/dl/ (国外下载地址)

 3.现在studygolang中文网也可以了https://studygolang.com/dl

下载版本:

mac darwin-adm64.tar.gz
linux amd64.tar.gz
windows amd64.msi

4.window编辑器 

  • atom配合go-plus插件
  • sublime配合gosublime插件;
  • emacs + spacemacs配置(相对来说比较麻烦,也是mac的一个不错的选择.)
  • Goland JetBrains

  直接安装的效果:

 

 

Windows推荐goland 

默认安装了1.7,可以自定义更新到最新版1.9

报错了

解决:export GOROOT_BOOTSTRAP=/usr/lib/go-1.7

1. 天然并发

Go语言引入了goroutine概念,它使得并发编程变得非常简单。通过使用goroutine而不是裸用操作系统的并发机制,以及使用消息传递来共享内存而不是使用共享内存来通信, Go语言让并发编程变得更加轻盈和安全。

通过在函数调用前使用关键字go,我们即可让该函数以goroutine方式执行。 goroutine是一种比线程更加轻盈、更省资源的协程。 Go语言通过系统的线程来多路派遣这些函数的执行,使得每个用go关键字执行的函数可以运行成为一个单位协程。当一个协程阻塞的时候,调度器就会自动把其他协程安排到另外的线程中去执行,从而实现了程序无等待并行化运行。而且调度的开销非常小,一颗CPU调度的规模不下于每秒百万次,这使得我们能够创建大量的goroutine,从而可以很轻松地编写高并发序,达到我们想要的目的。

Go语言实现了CSP(通信顺序进程, Communicating Sequential Process)模型来作为goroutine间的推荐通信方式。在CSP模型中,一个并发系统由若干并行运行的顺序进程组成,每个进程不能对其他进程的变量赋值。进程之间只能通过一对通信原语实现协作。

Go语言用channel(通道)这个概念来轻巧地实现了CSP模型。 channel的使用方式比较接近Unix系统中的管道(pipe)概念,可以方便地进行跨goroutine的通信。

 

在单核时代:一个线程就能把CPU跑满,没必要多个线程

多核:内存操作、io操作,可以多线程,多进程的流畅执行

Nginx:多进程架构

redis:单进程单线程,单进程只能跑满一个cpu,目前服务器大部分多于8核,redis一个机器上跑个6/7个,榨干cpu

go 天然支持并发,跑一个进程就能使用7/8个核

C++和Java线程是重量级线程,高并发-->线程池,
纯内存:8核8线程

go降低研发成本

goroute,轻量级线程,创建成千上万个goroute成为可能

 

 

2.垃圾回收

内存自动回收,不需要开发人员管理内存

开发人员专注业务实现,降低了心智负担

只需要new分配内存,不需要释放

因为垃圾回收功能的支持,开发者无需担心所指向的对象失效的问题,因此Go语言中不需要delete关键字,也不需要free()方法来明确释放内存。例如,对于以上的这个C语言例子,如果使用Go语言实现,我们就完全不用考虑何时需要释放之前分配的内存的问题,系统会自动帮我们判断,并在合适的时候(比如CPU相对空闲的时候)进行自动垃圾收集工作。

 

3. channel

管道,类似unix/linux中的pipe

多个goroute之间通过channel进行通信

支持任何类型

多返回值,一个函数返回多个值

 

 

 

1.任何一个代码文件隶属于一个包
2.import 关键字,引用其他包:import(“fmt”)
3.golang可执行程序,package main,并且有且只有一个main入口函数
4. 包中函数调用:
a. 同一个包中函数,直接调用
b. 不同包中函数,通过包名+点+函数名进行调用
5. 包访问控制规则:
大写意味着这个函数/变量是可导出的
小写意味着这个函数/变量是私有的,包外部不能访问

 

 1.编译运行

  跟go没有关系了,脱离了go

2.go run hello.go
3.各个版本的编译

gofmt -w hello.go代码完美

goimports -w hello.go 没有包就加上,有多余的包就删除

一键编译go build

go build github.com/greg1617/ningxin

一键测试:go test

go test github.com/greg1617/ningxin

一键下载更新依赖并编译go get

go get github.com/greg1617/ningxin

自动文档工具godoc

godoc -http=:9090

在线查看文档

godoc.org/github.com/golang/protobuf/proto