Go语言概述

1.Go语言的特点

1)从语言层面支持并发,实现简单

2)goroutine,轻量级线程,可实现大并发处理,高效利用多核

3)垃圾回收机制,内存自动回收,不需要开发人员管理

4)天然并发

5)吸收了管道通信机制,形成Go语言特有的管道channel,通过管道channel,可以实现不同的goroute之间的相互通信。

6)函数返回多个值

2.Go入门(万物基于hello world)

(1)go文件的后缀是.go

(2)package main

表示hello,go文件所在的包是main,在go中,每个文件都必须归属一个包。

(3)import "fmt"

表示:引入一个包,包名fmt,引入该包后,就可以使用fmt包的函数,比如:fmt.Println

(4)func main() {}

func 是一个关键字,表示一个函数

main是函数名,是一个主函数,即我们程序的入口。

(5)fmt.Println("hello")

表示调用fmt包的函数

3.Golang执行流程分析

(1)如果是对源码编译后,在执行,Go的执行流程如下图

(2)如果是对源码直接执行go run源码,Go的执行流程如下图

两种执行流程的区别

1)如果先编译生成了可执行文件,那么我们可以将该可执行文件拷贝到没有go开发环境的机器上,仍然可以运行

2)如果我们是直接go run ,go源代码,那么如果要在另外一个机器上这么运行,也需要go开发环境,否则无法运行。

3)在编译时,编译器会将程序运行依赖的库文件包含在可执行文件中,所以,可执行文件变大了很多

相关推荐
songtaiwu1 天前
golang开发日常注意
开发语言·数据库·golang
王中阳Go1 天前
Go后端 vs Go AI应用开发重点关注什么?怎么学?怎么面试?
人工智能·面试·golang
源代码•宸1 天前
GoLang并发示例代码1(关于逻辑处理器运行顺序)
开发语言·经验分享·后端·golang
卿雪1 天前
MySQL【存储引擎】:InnoDB、MyISAM、Memory...
java·数据库·python·sql·mysql·golang
路边草随风1 天前
go实现接口接收数据写入kafka
golang·kafka·gin
qq_548674931 天前
Go的env和bashrc的GOROOT配置不同
linux·开发语言·golang
Zfox_1 天前
【Go】反射
开发语言·后端·golang
Rinai_R1 天前
Golang 垃圾回收器执行链路分析
开发语言·后端·golang
古城小栈1 天前
深入解析Go泛型中的~struct{}
开发语言·后端·golang
卿雪1 天前
MySQL【数据类型】:CHAR 和 VARCHAR 的对比、VATCHAR(n) 和 INT(n) 里的 n 一样吗?
android·java·数据库·python·mysql·adb·golang