Golang输出世界上所有的语言文字

前言

下面这段代码,可以瞬间打印出世界上所有的语言文字,英文,日语,汉字,拉丁,汉语,甚至纳西文字,藏语,应有尽。而这一切,都源于对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()
        }
    }
}

展示结果部分如下(结果太多,只能部分展示):这里写图片描述
这里写图片描述
这里写图片描述

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

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

猜你喜欢

转载自blog.csdn.net/weixin_42940826/article/details/82713208
今日推荐