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

学习最基本的语法让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编码方式,任何字符都可以直接输出。就像此例中包含了英文、标点符号、韩文、日文等等。

三、小结

  1. Go语言使用关键字package来组织代码;
  2. main.main()函数(这个函数主要位于main包)是每个独立可运行程序的入口点;
  3. Go语言支持UTF-8字符串和标识符(因为UTF-8的发明者也是Go语言的发明者),所以它天生就具有多语言的支持。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值