学习最基本的语法让Go语言运行起来。
一、程序
package main
import "fmt"
func main() {
fmt.Printf("Hello, world or 你好,世界 or 안녕, 세상 or こんにちは、世界 \n")
}
输出如下:
Hello, world or 你好,世界 or 안녕, 세상 or こんにちは、世界
二、详解
1、package main
首先,要有个概念,Go语言是由关键字package来组织的。每一个可独立运行的Go语言程序,必定包含一个
package main
其通用的形式为:
package < packagename >
1、这一行是告诉我们当前文件属于哪个包,实例中就是属于 main包,它是一个可独立运行的包,它在编译后会产生可执行文件。除了main包之外,所有包都会生成 *.a 文件(即包文件)。
2、main包中必定含有一个 入口函数main,此函数既没有参数,也没有返回值。
2、import “fmt”
通过关键字import导入系统级别的 fmt包,这个包里有 Printf函数,是用来打印helloworld的,函数的调用是一个点:fmt.Printf,这和python十分相似。
包的概念和 python中的 module相同,他们都有个好处就是 模块化(把程序分成多个模块) 和 可重用性(每个模块都能被其他应用程序反复使用)。之后我们会编写自己的包。
3、func main() {}
通过关键词func定义了一个 main函数,函数体被放在 {} 中,和C++一样。可以看到 main函数是没有任何参数的,但我们可以编写带参数、返回0个或多个值的函数。
4、支持UTF-8
先来点理论:
UTF-8是一种变长字节编码方式。对于某一个字符的UTF-8编码,如果只有一个字节则其最高二进制位为0;如果是多字节,其第一个字节从最高位开始,连续的二进制位值为1的个数决定了其编码的位数,其余各字节均以10开头。UTF-8最多可用到6个字节。
如表: 1字节 0xxxxxxx 2字节 110xxxxx 10xxxxxx 3字节 1110xxxx 10xxxxxx
10xxxxxx 4字节 11110xxx 10xxxxxx 10xxxxxx 10xxxxxx 5字节 111110xx
10xxxxxx 10xxxxxx 10xxxxxx 10xxxxxx 6字节 1111110x 10xxxxxx 10xxxxxx
10xxxxxx 10xxxxxx 10xxxxxx
因此UTF-8中可以用来表示字符编码的实际位数最多有31位,即上表中x所表示的位。除去那些控制位(每字节开头的10等),这些x表示的位与UNICODE编码是一一对应的,位高低顺序也相同。
实际将UNICODE转换为UTF-8编码时应先去除高位0,然后根据所剩编码的位数决定所需最小的UTF-8编码位数。
因此那些基本ASCII字符集中的字符(UNICODE兼容ASCII)只需要一个字节的UTF-8编码(7个二进制位)便可以表示。
说人话就是,这个Go语言支持UTF-8编码方式,任何字符都可以直接输出。就像此例中包含了英文、标点符号、韩文、日文等等。
三、小结
- Go语言使用关键字package来组织代码;
- main.main()函数(这个函数主要位于main包)是每个独立可运行程序的入口点;
- Go语言支持UTF-8字符串和标识符(因为UTF-8的发明者也是Go语言的发明者),所以它天生就具有多语言的支持。