• 万能的芝麻酱
    2019-03-11
    关于字符集编码的知识,池大还是冯达曾经推送过阮一峰老师的博客,讲的很清晰,我每次糊涂的时候就打开重新开一遍……(http://www.ruanyifeng.com/blog/2007/10/ascii_unicode_and_utf-8.html?from=timeline)
     1
     8
  • psoracle
    2019-07-03
    atom每次启动时都会显示"updating go tools",在output中输入一堆go get -u github.com/xxx,怎么禁止?
    
     1
  • stopper
    2019-05-29
    建议老师解释,为什么要以slice设计string

    作者回复: 这个问题其实官方并没有给出解释,我个人认为string通过slice来实现,可以利用不同slice重用后端连续存储空间的概念(参考该课程相关章节)。这样来实现与其他语言类似的相同内容的字符串复用同一存储空间, 甚至子串也可重用存储空间。

            str1 := "Hello"
        str2 := "Hello"
        header1 := (*reflect.StringHeader)(unsafe.Pointer(&str1))
        header2 := (*reflect.StringHeader)(unsafe.Pointer(&str2))
        fmt.Println(header1.Data == header2.Data) //true

    
     1
  • Flygar
    2019-03-14
    // string is the set of all strings of 8-bit bytes, conventionally but not
    // necessarily representing UTF-8-encoded text. A string may be empty, but
    // not nil. Values of string type are immutable.
    type string string

    // byte is an alias for uint8 and is equivalent to uint8 in all ways. It is
    // used, by convention, to distinguish byte values from 8-bit unsigned
    // integer values.
    type byte = uint8

    // rune is an alias for int32 and is equivalent to int32 in all ways. It is
    // used, by convention, to distinguish character values from integer values.
    type rune = int32
    展开
    
     1
  • kkgo
    2019-03-11
    rune()用来打印unicode编码吗?

    作者回复: 可以用来获取string中的unicode字符,

    
     1
  • 愚者
    2020-01-02
    已知utf-8编码下的"严"就是EAB8A5,想问下\x 表示什么意思呢

    作者回复: 表示后面的内容是16进制的编码

    
    
  • 青青树
    2019-12-11
    根据个人实验:[]rune("string") 把string类型强制转换为rune切片,转换过程不是在string的存储二进制每四个字节即为一个rune数字的单纯二进制拷贝转换,而是通过utf-8的编码规则,转换为unicode code point,如果不是通过utf-8编码规则的转换的话,那么也就意味着string类型也可以每两个字节转换为[]int16,通过个人测试是不可以转换的,老师在讲解中说可以写入任何二进制数据,经过实验这个需要个前提是不违背utf-8编码规则,如果违背了编码规则,写入没有问题,但是统计长度和unicode code point转换(也就是转为[]rune)的时候就会出现一些意外结果,比如"中"字:
    unicode code point :20013(4E2D) 1001110 00101101,
    根据utf-8编码规则应该是3字节,
    按1110xxxx 10xxxxxx 10xxxxxx 填充后得到,
    11100100 10111000 10101101(E4B8AD),
    那么我们破坏utf-8编码规则 将最后的字节10xxxxxx 改为00xxxxxx,
    即10101101改为00101101 后得到11100100 10111000 00101101(E4B82D),
    将E4B82D当字符串写入:
    s := "\xe4\xb8\x2d"
    r := []rune(s)
    t.log(len(s))//3
    t.log(r)//[65533 65533 45]
    这个unicode code point 已经完全不靠谱了,
    而后又测试将其转换为[]byte类型,发现就是简单暴力的单字节的二进制拷贝转换(228 184 45)。没有utf-8这种隐藏规则。
    展开
    
    
  • SuoLocke
    2019-10-16
    你好,我又一个Atom配置的问题请教一下,我看你保存之后就可以自动编译运行,运行之后可以输出结果,但是我的运行不能输出结果, 只是提示与执行pass,没有输出代码中log结果,想要log是要安装设么包才可的?
    
    
  • stopper
    2019-05-29
    全程快进看,感觉可用的内容不多
    
    
  • GeekConsole.net
    2019-03-25
    你看,遍历string的时候,实际自动把string转成了rune再遍历。而不是根据 len(string)的byte数组个数
    
    
  • 王景迁
    2019-03-13
    为什么string要设计成切片
    
    
  • yrion
    2019-03-13
    rune用来提取其中的unicode

    作者回复: 同样可以输出unicode字符

    
    
我们在线,来聊聊吧