前言
下面这段代码,可以瞬间打印出世界上所有的语言文字,英文,日语,汉字,拉丁,汉语,甚至纳西文字,藏语,应有尽。而这一切,都源于对hello world代码研究的一个小灵感,结果并不是最重要的,可能对于大神来说这一切都是雕虫小技,但是我觉得自己的想法和思考的过程最来之不易,难能可贵,值得记录下来。
开始
先来引入一个hello world!
func main() {
a:="helloworld"
for i:=0;i<len(a) ;i++ {
fmt.Printf("%c",a[i])
}
}
ok!毫无悬念,打印出了helloworld。
于是我就想,若是换上我们博大精深的汉字会怎样呢?!
继续实践!
func main() {
a:="hello世界"
for i:=0;i<len(a) ;i++ {
fmt.Printf("%c",a[i])
}
}
输出结果:
居然对我们汉字这么不友好,直接给出了看不懂的乱码。
这是为什么呢?!搜索资料发现,咱们的汉字要占三个字节,若是我们打印出len(a),输出的结果是11,那怎么样才能让我们的计算机分别打印出世界的世和世界的界呢? 小编思索后发现这两种方法:
方法一,使用智能的for range遍历的方法,for range会智能的帮助我们识别我们想要的有效value,代码如下:
ok,成功打印出了世界二字,而且细心的同学会发现,‘世’的下标为5,到‘界’下标就成了8,这也验证了汉字占了三个字节长度。
因此,使用下标,方法二就诞生了!
方法二:
那么,为啥他们英文字母有着对应的ascii码,咱们中文是怎么存在的?!让我们回到for range的那段代码
ok!我们发现原来中文也有自己的专属码世界对应的分别是19990和30028,这叫作unicode码,原来是因为go语言原生支持unicode标准,可以使用GO处理世界上任何自然语言!
因此,小编脑洞打开,大胆实验,想看看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()
}
}
}
展示结果部分如下(结果太多,只能部分展示):
几乎世界上所有的文字都源源不断的输送到眼前,看起来很高大上的样子。