Golang输出世界上所有的语言文字(Unicode的力量)

前言

下面这段代码,可以瞬间打印出世界上所有的语言文字,英文,日语,汉字,拉丁,汉语,甚至纳西文字,藏语,应有尽。而这一切,都源于对hello world代码研究的一个小灵感,结果并不是最重要的,可能对于大神来说这一切都是雕虫小技,但是我觉得自己的想法和思考的过程最来之不易,难能可贵,值得记录下来。
开始

先来引入一个hello world!

  func main()  {
	a:="helloworld"
	for i:=0;i

ok!毫无悬念,打印出了helloworld。
这里写图片描述

于是我就想,若是换上我们博大精深的汉字会怎样呢?!
继续实践!

func main()  {
	a:="hello世界"
	for i:=0;i

输出结果:
这里写图片描述
居然对我们汉字这么不友好,直接给出了看不懂的乱码。
这是为什么呢?!搜索资料发现,咱们的汉字要占三个字节,若是我们打印出len(a),输出的结果是11,那怎么样才能让我们的计算机分别打印出世界的世和世界的界呢? 小编思索后发现这两种方法:
方法一,使用智能的for range遍历的方法,for range会智能的帮助我们识别我们想要的有效value,代码如下:
Golang输出世界上所有的语言文字(Unicode的力量)_第1张图片
ok,成功打印出了世界二字,而且细心的同学会发现,‘世’的下标为5,到‘界’下标就成了8,这也验证了汉字占了三个字节长度。

因此,使用下标,方法二就诞生了!
方法二:
Golang输出世界上所有的语言文字(Unicode的力量)_第2张图片

那么,为啥他们英文字母有着对应的ascii码,咱们中文是怎么存在的?!让我们回到for range的那段代码

Golang输出世界上所有的语言文字(Unicode的力量)_第3张图片
ok!我们发现原来中文也有自己的专属码世界对应的分别是19990和30028,这叫作unicode码,原来是因为go语言原生支持unicode标准,可以使用GO处理世界上任何自然语言!
如果有一种编码,将世界上所有的符号都纳入其中。每一个符号都给予一个独一无二的编码,那么乱码问题就会消失。这就是 Unicode,就像它的名字都表示的,这是一种所有符号的编码。

因此,小编脑洞打开,大胆实验,想看看go是不是能打印出世界上所有的文字,代码很简单,利用我们前面所理解的,实现如下

func main() {
	var i int=0
	var t int=0
	for  {
		fmt.Printf("%c",i)
		i++
		//从零一直打印
		time.Sleep(time.Nanosecond)
		//如果打印的太快,有时会不出结果,所以要停顿一下
	//以下几行是每隔60个换一下行,方便观察结果
		t++
		if t%60==0 {
			fmt.Println()
		}
	}
}

展示结果部分如下(结果太多,只能部分展示):Golang输出世界上所有的语言文字(Unicode的力量)_第4张图片
Golang输出世界上所有的语言文字(Unicode的力量)_第5张图片
Golang输出世界上所有的语言文字(Unicode的力量)_第6张图片

几乎世界上所有的文字都源源不断的输送到眼前,看起来很高大上的样子。

以上就是我的一个简单的小发现了,欢迎大家一起来交流哦!

你可能感兴趣的:(golang)