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

相关推荐
飞川撸码4 小时前
【LeetCode 热题100】网格路径类 DP 系列题:不同路径 & 最小路径和(力扣62 / 64 )(Go语言版)
算法·leetcode·golang·动态规划
roman_日积跬步-终至千里12 小时前
【Go语言基础【14】】defer与异常处理(panic、recover)
golang
孔令飞13 小时前
Kubernetes 节点自动伸缩(Cluster Autoscaler)原理与实践
ai·云原生·容器·golang·kubernetes
我的golang之路果然有问题18 小时前
云服务器部署Gin+gorm 项目 demo
运维·服务器·后端·学习·golang·gin
孔令飞19 小时前
Go 为何天生适合云原生?
ai·云原生·容器·golang·kubernetes
YGGP1 天前
吃透 Golang 基础:数据结构之 Map
开发语言·数据结构·golang
march of Time1 天前
go工具库:hertz api框架 hertz client的使用
开发语言·golang·iphone
余厌厌厌1 天前
go语言学习 第9章:映射(Map)
服务器·学习·golang
roman_日积跬步-终至千里1 天前
【Go语言基础【15】】数组:固定长度的连续存储结构
golang
cccc来财1 天前
Go中的协程并发和并发panic处理
开发语言·后端·golang