简介

Go语言是一种新的语言,一种并发的、带垃圾回收的、快速编译的语言。它具有以下特点:
1.它可以在一台计算机上用几秒钟的时间编译一个大型的Go程序。
2.Go语言为软件构造提供了一种模型,它使依赖分析更加容易,且避免了大部分C风格include文件与库的开头。
3.Go语言是静态类型的语言,它的类型系统没有层级。因此用户不需要在定义类型之间的关系上花费时间,这样感觉起来比典型的面向对象语言更轻量级。
4.Go语言完全是垃圾回收型的语言,并为并发执行与通信提供了基本的支持。
按照其设计,Go打算为多核机器上系统软件的构造提供一种方法。
Go语言是一种编译型语言,它结合了解释型语言的游刃有余,动态类型语言的开发效率,以及静态类型的安全性。它也打算成为现代的,支持网络与多核计算的语言。要满足这些目标,需要解决一些语言上的问题:一个富有表达能力但轻量级的类型系统,并发与垃圾回收机制,严格的依赖规范等等。这些无法通过库或工具解决好,因此Go也就应运而生了。
(引用自百度百科)

安装配置

1 根据操作系统选择不同的安装包

下载地址 https://golang.org/dl/

 

 

2 安装

根据不同的安装包有不同的安装方法,具体参考官网

3 设置环境变量

需要设置go的环境变量

1)go 的执行文件路径(GOROOT)加到系统的PATH环境变量中

2)工作目录的路径,设置GOPATH环境变量

4 Hello world sample

  1. // test
  2. package main
  3.  
  4. import (
  5. "fmt"
  6. )
  7.  
  8. func add(a int, b int) int {
  9. var sum int
  10. sum = a + b
  11. return sum
  12. }
  13.  
  14. func main() {
  15.  
  16. var add_res int
  17. add_res = add(100, 200)
  18. fmt.Println("Hello World!", add_res)
  19. }

helloworld

golang 语言特性

1 垃圾回收

内存自动回收,不需要人为管理内存

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

2 天然并发(CPU多核)

从语言层面支持并发,简单

goroute,轻量级线程(个人感觉类似python中的协程),管理底层的无力线程

基于CSP(Communicating Sequential Process)实现,在go中主要是channel和goroute,简介如下

  1. Channel
  2.  
  3. Golang中使用 CSP channel 这个概念。channel 是被单独创建并且可以在进程之间传递,它的通信模式类似于 boss-worker 模式的,一个实体通过将消息发送到channel 中,然后又监听这个 channel 的实体处理,两个实体之间是匿名的,这个就实现实体中间的解耦,其中 channel 是同步的一个消息被发送到 channel 中,最终是一定要被另外的实体消费掉的,在实现原理上其实是一个阻塞的消息队列。
  4. Goroutine
  5.  
  6. Goroutine 是实际并发执行的实体,它底层是使用协程(coroutine)实现并发,coroutine是一种运行在用户态的用户线程,类似于 greenthreadgo底层选择使用coroutine的出发点是因为,它具有以下特点:
  7.  
  8. 用户空间 避免了内核态和用户态的切换导致的成本
  9. 可以由语言和框架层进行调度
  10. 更小的栈空间允许创建大量的实例
  11.  
  12. 可以看到第二条 用户空间线程的调度不是由操作系统来完成的,像在java 1.3中使用的greenthread的是由JVM统一调度的(后java已经改为内核线程),还有在ruby中的fiber(半协程) 是需要在重新中自己进行调度的,而goroutine是在golang层面提供了调度器,并且对网络IO库进行了封装,屏蔽了复杂的细节,对外提供统一的语法关键字支持,简化了并发程序编写的成本。

channel&goroute

  1. // test
  2. package main
  3.  
  4. import (
  5. "time"
  6. )
  7.  
  8. func add(a int, b int) int {
  9. var sum int
  10. sum = a + b
  11. return sum
  12. }
  13.  
  14. func main() {
  15.  
  16. //var add_res int
  17. //add_res = add(100, 200)
  18. //go test_goroute(10, 20)
  19. //fmt.Println("Hello World!", add_res)
  20.  
  21. for i := 0; i < 100; i++ {
  22. go test_print(i)
  23. }
  24. time.Sleep(5)
  25. }

go并发

3 channel

管道,类似unix/linux中的pipe

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

支持任何类型

  1. // pipe
  2. package main
  3.  
  4. import (
  5. "fmt"
  6. )
  7.  
  8. func test_pipe() {
  9. pipe := make(chan int, 3)
  10. pipe <- 1
  11. pipe <- 2
  12. pipe <- 3
  13. fmt.Println(len(pipe))
  14. }

pipe.go

4 goroute和pipe的sample

  1. // sub
  2. package calc
  3.  
  4. func Sub(a int, b int, c chan int) {
  5. c <- (a - b)
  6. }

sub.go

  1. // add
  2. package calc
  3.  
  4. func Add(a int, b int, c chan int) {
  5. c <- (a + b)
  6. }

add.go

  1. // calculator
  2. package main
  3.  
  4. import (
  5. "day1/calc"
  6. "fmt"
  7. )
  8.  
  9. func main() {
  10. var pipe chan int
  11. pipe = make(chan int, 1)
  12. go calc.Add(100, 200, pipe)
  13. go calc.Sub(100, 200, pipe)
  14. sum := <-pipe
  15. sub := <-pipe
  16. fmt.Println(sum, sub)
  17. }

calculator

1 和python一样,把相同功能的代码放到一个目录,称之为包

2 包可以被其他包引用

3 main包是用来生成可执行文件,每个程序只能有一个main包

4 包主要的用途是提高代码的可复用性

5 一般go项目路径说明

/project/src/       源文件

bin/        可执行文件

vendor/   第三方文件

pkg/ 静态库

6 Go中如果函数名的首字母大写,表示该函数是公有的,可以被其他程序调用,如果首字母小写,该函数就是是私有的,因此我们只能调用其他包文件中的公有函数

7 包的别名

  1. import (
  2. f "fmt"
  3. )
  4.  
  5. func main() {
  6.  
  7. n := 10
  8. for i := 0; i <= n; i++ {
  9.  
  10. f.Printf("%d+%d=%d\n", i, n-i, n)
  11. }
  12.  
  13. }

8 每个源文件都可以包含一个init函数,这个init函数自动被go运行框架调用

  1. // main
  2. package main
  3.  
  4. import (
  5. "fmt"
  6. )
  7.  
  8. func init() {
  9. fmt.Println("----initiation----")
  10. }

9 只初始化包,并不引用

  1. // main
  2. package main
  3.  
  4. import (
  5. _ "path/external_func"
  6. )
  7.  
  8. func init() {
  9. fmt.Println("----initiation----")
  10. }

go 简介与包的更多相关文章

  1. Linux程序包管理.md

    rpm 简介 RPM包管理员(简称RPM,全称为The RPM Package Manager)是在Linux下广泛使用的软件包管理器.RPM此名词可能是指.rpm的文件格式的软件包,也可能是指其本身 ...

  2. Python标准库02 时间与日期 (time, datetime包)

    作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! Python具有良好的时间和日期管理功能.实际上,计算机只会维护一个挂钟时间(wa ...

  3. Support Library官方教程(2)各支援包的特性详介(含表)*

    快速阅读 包名  作用  位置 是否有资源 v4 提供了最多的api <sdk>/extras/android/support/v4/ y Multidex 把DEX文件生成apk < ...

  4. glide简介

    golang包管理工具glide简介   golang包管理工具glide简介 前言 golang是一个十分有趣,简洁而有力的开发语言,用来开发并发/并行程序是一件很愉快的事情.在这里我感受到了其中一 ...

  5. [强烈推荐]ORACLE PL/SQL编程详解之七:程序包的创建与应用(聪明在于学习,天才在于积累!)

    原文:[强烈推荐]ORACLE PL/SQL编程详解之七:程序包的创建与应用(聪明在于学习,天才在于积累!) [强烈推荐]ORACLE PL/SQL编程详解之七: 程序包的创建与应用(聪明在于学习,天 ...

  6. UML之包图

    包图是UML中用类似于文件夹的符号表示的模型元素的组合,系统中的每个元素都只能为一个包所有,一个包可嵌套在另一个包中,使用包图可将相关元素归入一个系统,一个包中包含附属包.图表或单个元素.简单的来说, ...

  7. DAY16、模块和包

    一.模块 1.模块的加载顺序:内存 =>内置 =>sys.path(一系列自定义模块) 2.sys.path:环境变量,存放文件路径的列表 重点:默认列表第一个元素就是当前被执行文件所在的 ...

  8. Linux学习之RPM包管理-rpm命令管理(十六)

    Linux学习之RPM包管理-rpm命令管理 目录 简介 RPM包依赖性 包全名与包名 rpm软件包安装 rpm软件包卸载 升级降级rpm软件包 rpm软件包的查询 rpm软件包校验 简介 RPM是R ...

  9. 并发之java.util.concurrent.atomic原子操作类包

    15.JDK1.8的Java.util.concurrent.atomic包小结 14.Java中Atomic包的原理和分析 13.java.util.concurrent.atomic原子操作类包 ...

随机推荐

  1. PAT_A1080#Graduate Admission

    Source: PAT A1080 Graduate Admission (30 分) Description: It is said that in 2011, there are about 10 ...

  2. 实验报告&总结

    Java实验报告 班级计科二班 学号 20188429 姓名 罗璇哲 完成时间 评分等级 实验三 String类的应用 一. 实验目的 (1) 掌握类String类的使用: (2) 学会使用JDK帮助 ...

  3. JUC源码分析-其它工具类(一)ThreadLocalRandom

    JUC源码分析-其它工具类(一)ThreadLocalRandom ThreadLocalRandom 是 JDK7 在 JUC 包下新增的随机数生成器,它解决了 Random 在多线程下多个线程竞争 ...

  4. 调用API接口,查询手机号码归属地(2)

    使用pymysql pip install pymysql 创建mysql测试表 CREATE TABLE `userinfo` ( `id` int(20) NOT NULL AUTO_INCREM ...

  5. USACO2012 Moo /// 模拟 oj21548

    大致题意: 递归地描述序列:设S(0)为3个字符的序列“mo o”.然后在较长的序列小号(ķ)通过取序列的拷贝获得小号(ķ -1),则“摩... O”与ķ 2 O公司,然后该序列的另一个拷贝小号(ķ  ...

  6. usb-host与外设通信(二)

    本文是接着上一篇的的usb-host与外设通信(一)接着写的 3.枚举设备 当你的程序运行时,如果应用程序对当前连接的USB设备都感兴趣的,程序可以枚举所以当前的设备.使用getDeviceList( ...

  7. python_learn Ⅰ

    基于 廖雪峰python3教程 学习. 目录: 01_输入输出.py 02_list.tuple.py 03_条件判断.py 04_循环.py 05_利用循环排序.py 06_自定义3元2次方程的根求 ...

  8. Vue引入日期格式插件moment.js

    因为需求需要,接口传递过来的日期格式是一个时间戳,因此需要进行格式转换,老大给了插件地址,让我自己研究 插件地址:http://momentjs.cn/ 因为没有使用过,所有就开始各种百度,参考各位大 ...

  9. Redis 小调研

    一. 概况: Redis是一款开源的.网络化的.基于内存的.可进行数据持久化的Key-Value存储系统.它的数据模型建立在外层,类似于其它结构化存储系统,是通过Key映射Value的方式来建立字典以 ...

  10. github合并分支到master

    (1)切换到master分支 git checkout master (2) 将backup分支的代合并到master git merge backup (3) 查看状态 git status (4) ...