下载APP
登录
关闭
讲堂
算法训练营
Python 进阶训练营
企业服务
极客商城
客户端下载
兑换中心
渠道合作
推荐作者
当前播放: 12 | 字符串
00:00 / 00:00
标清
  • 标清
1.0x
  • 2.0x
  • 1.5x
  • 1.25x
  • 1.0x
  • 0.5x
网页全屏
全屏
00:00
付费课程,可试看

Go语言从入门到实战

共55讲 · 55课时,约700分钟
6092
免费
01 | Go语言课程介绍
免费
02 | 内容综述
免费
03 | Go语言简介:历史背景、发...
免费
04 | 编写第一个Go程序
免费
05 | 变量、常量以及与其他语言...
06 | 数据类型
07 | 运算符
08 | 条件和循环
09 | 数组和切片
10 | Map声明、元素访问及遍历
11 | Map与工厂模式,在Go语言...
12 | 字符串
13 | Go语言的函数
14 | 可变参数和defer
15 | 行为的定义和实现
16 | Go语言的相关接口
17 | 扩展与复用
18 | 不一样的接口类型,一样的...
19 | 编写好的错误处理
20 | panic和recover
21 | 构建可复用的模块(包)
22 | 依赖管理
23 | 协程机制
24 | 共享内存并发机制
25 | CSP并发机制
26 | 多路选择和超时
27 | channel的关闭和广播
28 | 任务的取消
29 | Context与任务取消
30 | 只运行一次
31 | 仅需任意任务完成
32 | 所有任务完成
33 | 对象池
34 | sync.pool对象缓存
35 | 单元测试
36 | Benchmark
37 | BDD
38 | 反射编程
39 | 万能程序
40 | 不安全编程
41 | 实现pipe-filter framew...
42 | 实现micro-kernel frame...
43 | 内置JSON解析
44 | easyjson
45 | HTTP服务
46 | 构建RESTful服务
47 | 性能分析工具
48 | 性能调优示例
49 | 别让性能被锁住
50 | GC友好的代码
51 | 高效字符串连接
52 | 面向错误的设计
53 | 面向恢复的设计
54 | Chaos Engineering
55 | 结束语
本节摘要
展开

精选留言(11)

  • 关于字符集编码的知识,池大还是冯达曾经推送过阮一峰老师的博客,讲的很清晰,我每次糊涂的时候就打开重新开一遍……(http://www.ruanyifeng.com/blog/2007/10/ascii_unicode_and_utf-8.html?from=timeline)
    1
    8
  • 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
  • 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
  • 2019-03-11
    rune()用来打印unicode编码吗?

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

    1
  • 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这种隐藏规则。
    展开
  • 2019-10-16
    你好,我又一个Atom配置的问题请教一下,我看你保存之后就可以自动编译运行,运行之后可以输出结果,但是我的运行不能输出结果, 只是提示与执行pass,没有输出代码中log结果,想要log是要安装设么包才可的?
  • 2019-07-03
    atom每次启动时都会显示"updating go tools",在output中输入一堆go get -u github.com/xxx,怎么禁止?
  • 2019-05-29
    全程快进看,感觉可用的内容不多
  • 2019-03-25
    你看,遍历string的时候,实际自动把string转成了rune再遍历。而不是根据 len(string)的byte数组个数
  • 2019-03-13
    为什么string要设计成切片
  • 2019-03-13
    rune用来提取其中的unicode

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