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)在编译时,编译器会将程序运行依赖的库文件包含在可执行文件中,所以,可执行文件变大了很多

相关推荐
阿狸远翔7 小时前
Protobuf 和 protoc-gen-go 详解
开发语言·后端·golang
a努力。10 小时前
字节Java面试被问:系统限流的实现方式
java·开发语言·后端·面试·职场和发展·golang
小高Baby@11 小时前
使用Go语言中的Channel实现并发编程
开发语言·后端·golang
卜锦元12 小时前
Golang后端性能优化手册(第三章:代码层面性能优化)
开发语言·数据结构·后端·算法·性能优化·golang
Grassto13 小时前
从 GOPATH 到 Go Module:Go 依赖管理机制的演进
开发语言·后端·golang·go
shhpeng14 小时前
Go语言中 的 defer 语句
开发语言·后端·golang
是垚不是土15 小时前
基于DDNS-Go动态域名解析配置:实现多网络线路冗余切换方案
运维·开发语言·网络·阿里云·golang·运维开发
天远云服15 小时前
Go 语言实战:构建高并发天远“全国自然人人脸比对 V3”微服务网关
java·大数据·微服务·golang
Tony Bai18 小时前
Go 性能分析的“新范式”:用关键路径分析破解高并发延迟谜题
开发语言·后端·golang
L Jiawen20 小时前
【Golang基础】基础知识(上)
开发语言·后端·golang