1.切片的内部结构,三个参数,指向某个连续数组的指针ptr,元素的个数len,内部数组的容量cap
2.切片容量的增长方式,按指数级增长,1 2 4 8 16 32 ....
3.切片的定义
s1 := []int{1,2,3,4}
s2 := make([]int, 3, 5)
数组的定义
var arr [3]int
arr1 := [4]int{1,2,3,4}
arr2 := [...]int{1,2,4,5}
4.切片的容量可变,数组不可变
相同维度,相同个数的数组可以比较,切片不能比较
5.Map 元素的访问,在访问的key不存在时,仍会返回零值,不能通过返回nil来判断元素是否存在。需要用ok来判断
6.string是数据类型,不是引用或指针类型。string是只读的byte slice,len函数是它所包含的byte数。string的byte数组可以存放任何数据。
7.Thread vs. Groutine
(1)创建时默认的stack的大小
JDK5以后Java Thread stack 默认为1M
Groutine的stack初始化大小为2k
(2)和KSE(Kernel Space Entity)的对应关系
Java Thread 是1:1
Groutine是M:NM:N
M为系统线程;G为一个goroutine;P为处理器,用来处理goroutine,维护着一个goroutine的队列;S,调度器,维护有存储M和G的队列以及调度器的一些状态信息等。
当某个goroutine被系统中断(例如IO),P会把自己移动到另一个可使用的系统线程M1中,继续执行挂在P上的goroutine。当被中断的goroutine被唤醒之后,会加入到某个P的协程等待队列当中,或者全局队列当中。当协程被中断时,协程的运行状态会保存在协程对象里,被唤醒后这些状态会重新写入寄存器,继续运行。