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

相关推荐
kite01211 小时前
Gin 与消息队列集成:使用 RabbitMQ 处理异步任务
golang·rabbitmq·gin
源代码•宸1 小时前
goframe框架签到系统项目(安装 redis )
服务器·数据库·经验分享·redis·后端·缓存·golang
顾安r1 小时前
12.16 脚本网页 Golang标准库
golang·html
古城小栈10 小时前
Docker 多阶段构建:Go_Java 镜像瘦身运动
java·docker·golang
serendipity_hky15 小时前
【go语言 | 第2篇】Go变量声明 + 常用数据类型的使用
开发语言·后端·golang
周杰伦_Jay16 小时前
【Eino框架】Go语言驱动的LLM应用开发新范式
开发语言·后端·golang
2501_9419820518 小时前
Go 进阶:发送文件/图片消息的流程与实现
开发语言·后端·golang
2501_9448755119 小时前
Go后端工程师
开发语言·后端·golang
理人综艺好会19 小时前
Redis学习之go-redis
redis·学习·golang
bing.shao19 小时前
Golang WaitGroup 踩坑
开发语言·数据库·golang