Go语言学习——2、Hello, world

    xiaoxiao2022-07-14  158

    学习最基本的语法让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语言的发明者),所以它天生就具有多语言的支持。
    最新回复(0)