Go 语言入门
开始学习 Go 编程语言前,先来运行一个最简单的go语言代码。(备注:以下操作使用window系统)
使用go语言实现“hello,world”
打开D盘,创建一个目录 hello
进入hello目录,创建一个文件 hello.go
helllo.go的示例代码:
package main
import "fmt"
func main() {
var s string = "Hello, World!"
/* 这是我的第一个简单的程序 */
fmt.Println(s)
}
使用CMD或者Powershell 打开执行
D:\hello> go run .
Hello, World!
或者
D:\hello> go run hello.go
Hello, World!
如果要生成二进制文件,则需要使用build命令
D:\hello> go build hello.go
D:\hello> .\hello.exe
Hello, World!
从上面代码中可以看出,Go 语言的基础组成有以下几个部分:
- 包声明
- 引入包
- 函数
- 变量
- 语句 & 表达式
- 注释
让我们来详细解释hello.go文件中代码的各个部分:
package main
声明一个main包。包是一种对函数进行分组的方式,它由同一目录中的所有文件组成。
go源文件中非注释的第一行必须指明文件属于哪个包,package main表示一个可独立执行的程序,每个 Go 应用程序都包含一个名为 main 的包。
import "fmt"
导入流行的 fmt
包,其中包含格式化文本的功能,包括打印到控制台。该包是您安装 Go 时获得的 标准库包之一 。
func main() {}
程序开始执行的函数。main 函数是每一个可执行程序所必须包含的,一般来说应用启动后第一个执行的函数(如果有 init() 函数则会先执行该函数)。
var s string = "Hello, World!"
定义一个变量s,类型是string,值为"Hello, World!"
/* 这是我的第一个简单的程序 */
在程序执行时将被忽略。单行注释是最常见的注释形式,你可以在任何地方使用以 // 开头的单行注释。
多行注释也叫块注释,均已以 /* 开头,并以 */ 结尾,且不可以嵌套使用,多行注释一般用于包的文档描述或注释成块的代码片段。
fmt.Println(s)
将字符串输出到控制台,并在最后自动增加换行字符 \n。使用 fmt.Print(s + "\n") 可以得到相同的结果。
Print 和 Println 这两个函数也支持使用字符,如:fmt.Println(“hellow,world!")。如果没有特别指定,它们会以默认的打印格式输出到控制台。
注意:
当标识符(包括常量、变量、类型、函数名、结构字段等等)以一个大写字母开头,如:Group1,那么使用这种形式的标识符的对象就可以被外部包的代码所使用(客户端程序需要先导入这个包),这被称为导出(像面向对象语言中的 public);标识符如果以小写字母开头,则对包外是不可见的,但是他们在整个包的内部是可见并且可用的(像面向对象语言中的 protected )。
注意:
需要注意的是 { 不能单独放在一行,所以以下代码在运行时会产生错误:
package main
import "fmt"
func main()
{ // 错误,{ 不能在单独的行上
fmt.Println("Hello, World!")
}