当进行Go程序开发时,需要注意以下几点:
1、代码可读性:尽可能使用有意义的变量名和注释,确保代码易于理解和维护。
2、错误处理:Go语言有很好的错误处理机制,应该合理地处理错误,以便于排除错误。
3、内存管理:Go语言自动管理内存,但是如果存在大量的内存分配和垃圾回收,会影响程序性能,因此需要注意内存的使用。
4、并发处理:Go语言是一种并发编程语言,可以充分利用多核处理器。但需要注意协程之间的数据同步和互斥问题。
5、测试:编写高品质的测试代码可确保程序正确性和稳定性。
6、性能优化:尽可能的减少内存分配和垃圾回收,使用适当的数据类型和算法。
希望这些注意点能够帮助你进行Go程序开发,具体我们实操以下。
环境部署
系统:Ubuntu 21.10(Linux实体机)
需求
要求开发一个 hello.go 程序,可以输出 hello,world
开发的步骤
1、使用 goland 作为程序开发编辑器;
2、将代码编写到扩展名为 hello.go 的文件中;
3、通过 go run 命令查看 hello.go 运行效果;
4、通过 go build 命令对该 go文件进行编译,生成系统可执行文件;
5、在dos命令下执行生成的可执行文件;
go程序目录结构建议
go 程序代码编写
将编写的代码存储到 project/main/hello.go 文件中,其中 .go 是 golang编程语言可识别的文件后缀
package main
import `fmt`
func main() {
fmt.Println("hello,world")
}
解释:
go run 查看运行效果
# 在 project/main 执行以下命令
go run hello.go
使用 go run 这种方式执行 go 程序源码,会先载入 hello.go 的源码并由 go 进行编译成二进制码让计算机能识别执行。
go build 构建可执行文件并运行
# 在 project/main 执行编译命令将生成可执行文件 hello
go build hello.go
# 查看是否编译成功
ll
# 执行二进制可执行文件(在linux下开发go和在windows开发基本是一样的,区别在linux运行可执行的程序时是以 ./文件名 的方式)
./hello
# 见下图操作过程
使用 go build 这种方式执行 go 程序源码打包成计算机可直接执行的二进制文件,与 go run 的区别在于 go run 是需要进行源码编译执行,go build 生成的文件是计算机可直接执行的文件。
go 执行流程分析
go build(速度快)
go run
两种执行流程方式区别
1、如果我们先编译生成了可执行文件,那么我们可以将该可执行文件拷贝到没有go开发环境的系统上,任然是可以直接执行。
2、如果我们是直接 go run go源代码,那么如果要在另外一个机器上这么运行,也需要go开发环境,否则无法执行。
3、在编译时,编译器会将程序运行依赖的库文件包含在可执行文件中,所以,可执行文件变大了很多。
编译和运行说明
什么是编译?
1、有了go源码文件,通过编译器将其编译成机器可以识别的二进制码文件。
2、该源文件目录下,通过 go build 对 hello.go 文件进行编译。可以指定生成可执行文件名,其中在 windows下必须是 .exe 后缀。
3、编译的时候可以用 -o xx 生成指定的编译文件名,例如linux下 go build -o test hello.go。
4、如果程序没有错误,没有任何提示,会在当前目录下出现一个可执行文件(windows下是.exe,linux下是一个可执行文件),该文件是二进制码文件,是可以直接执行的程序。
5、如果程序有错误,编译时会在错误的那行报错。
什么是运行?
1、直接运行生成的可执行Go程序,比如 hello
2、通过运行工具 go run 对源码文件进行运行
go 程序开发注意事项(重点)
1、go源文件以“go”为文件名的扩展名。
2、go应用程序的执行入口是 main() 方法。
3、go语言严格区分大小写。
4、go方法由一条条语句构成,每个语句后不需要分号(go语言会在编译时为每行后面自动加上分号),这也体现出golang的简洁性。
5、go编译器是一行行进行编译的,因此我们一行就一条语句,不能把多条语句写在同一行,否则会报错。
6、go语言 定义的变量 或者 import 的包如果没有使用到,代码不能编译通过。
7、大括号都是成双成对出现的,缺一不可。