在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
1.https://dl.gocn.io/ (国内下载地址)
2.https://golang.org/dl/ (国外下载地址) 3.现在studygolang中文网也可以了https://studygolang.com/dl 下载版本: mac darwin-adm64.tar.gz 4.window编辑器
直接安装的效果:
Windows推荐goland
二 、Ubuntu安装apt install golang-go
root@greg:# go env
GOARCH="amd64"
GOBIN=""
GOEXE=""
GOHOSTARCH="amd64"
GOHOSTOS="linux"
GOOS="linux"
GOPATH=""
GORACE=""
GOROOT="/usr/lib/go-1.7"
GOTOOLDIR="/usr/lib/go-1.7/pkg/tool/linux_amd64"
CC="gcc"
GOGCCFLAGS="-fPIC -m64 -pthread -fmessage-length=0 -fdebug-prefix-map=/tmp/go-build765188684=/tmp/go-build -gno-record-gcc-switches"
CXX="g++"
CGO_ENABLED="1"
默认安装了1.7,可以自定义更新到最新版1.9 root@greg:/usr/local/src/go1.9.2/src# ./make.bash
##### Building Go bootstrap tool.
cmd/dist
ERROR: Cannot find /root/go1.4/bin/go.
Set $GOROOT_BOOTSTRAP to a working Go tree >= Go 1.4.
报错了 解决:export GOROOT_BOOTSTRAP=/usr/lib/go-1.7 初始化环境
GOROOT放置go的标准库和工具链
$HOME/local/go (linux,mac)
c:\local\go (windows)
GOPATH放置第三方代码和自己的工程
$HOME/go(linux,mac)
c:\go(windows)
PATH
export PATH=$GOROOT/bin:$GOPATH/bin:$PATH
vim ~/.bashrc
export GOROOT=$HOME/local/go
export GOPATH=$HOME/go
export PATH=$GOROOT/bin:$GOPATH/bin:$PATH
我的Ubuntu是这样的
GOPATH="/go"
GOROOT="/usr/local/src/go"
export PATH=$GOROOT/bin:$GOPATH/bin:$PATH
三、golang特性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线程是重量级线程,高并发-->线程池, go降低研发成本 goroute,轻量级线程,创建成千上万个goroute成为可能
package main import( "time" "fmt" ) func test_goroute(a int) { fmt.Println(a) } func main() { for i := 0; i < 100; i++ { go test_goroute(i) } time.Sleep(time.Second) }
2.垃圾回收内存自动回收,不需要开发人员管理内存 开发人员专注业务实现,降低了心智负担 只需要new分配内存,不需要释放 因为垃圾回收功能的支持,开发者无需担心所指向的对象失效的问题,因此Go语言中不需要delete关键字,也不需要free()方法来明确释放内存。例如,对于以上的这个C语言例子,如果使用Go语言实现,我们就完全不用考虑何时需要释放之前分配的内存的问题,系统会自动帮我们判断,并在合适的时候(比如CPU相对空闲的时候)进行自动垃圾收集工作。
3. channel管道,类似unix/linux中的pipe 多个goroute之间通过channel进行通信 支持任何类型 多返回值,一个函数返回多个值
package main import( "fmt" ) func Add(a int, b int) int { return a + b } func Sub(a int, b int) int { return a - b } func cal(a int, b int)(int,int) { sum := a + b avg := (a+b)/2 return sum, avg } func main() { sum := Add(100, 300) sub := Sub(100, 300) fmt.Println(cal(100,200)) fmt.Println("sum=",sum) fmt.Println("sub=", sub) }
四.hello golang程序
1.任何一个代码文件隶属于一个包
package main
import "fmt"
func main(){
fmt.Println("hello golang")
}
五.运行1.编译运行
go build hello.go
ll
-rwxr-xr-x 1 greg greg 1859967 12月 23 21:29 hello*
-rw-r--r-- 1 greg greg 75 12月 23 21:25 hello.go
greg@greg:~/go$ ./hello
hello golang
跟go没有关系了,脱离了go
greg@greg:~/go$ file hello hello: ELF 64-bit LSB executable, x86-64, version 1 (SYSV), statically linked, not stripped 2.go run hello.go
|
请发表评论