上一页 1 ··· 39 40 41 42 43 44 45 46 47 ··· 108 下一页
摘要: 进程、线程、协程 内存 进程: (1)操作系统会以进程为单位,分配系统资源 (CPU时间⽚、内存等资源),进程是资 源分配的最⼩单位。 (2)进程的安全性⽐较⾼ (3)通信成本就⽐较⼤ IPC 信号 |管道| 共享内存| socket⽹络通信| 共享⽂件 线程: (1)操作系统调度(CPU调度)执⾏ 阅读全文
posted @ 2020-09-24 22:49 Mr.peter 阅读(407) 评论(0) 推荐(0)
摘要: ACID理论 原⼦性(Atomicity) ⼀致性(Consistency) 隔离性(Isolation) 持久性(Durability) CAP理论 (1) ⼀致性Consistency “all nodes see the same data at the same time” ⼀旦数据更新完成 阅读全文
posted @ 2020-09-24 22:47 Mr.peter 阅读(248) 评论(0) 推荐(0)
摘要: 流?I/O操作? 阻塞? (1)流 ▪ 可以进⾏I/O操作的内核对象 ▪ ⽂件、管道、套接字…… ▪ 流的⼊⼝:⽂件描述符(fd) (2)I/O操作 所有对流的读写操作,我们都可 以称之为IO操作。 (3)阻塞 阻塞等待 不占⽤CPU宝贵的时间⽚ ⾮阻塞忙轮询 占⽤CPU,系统资源 在处理意⻅数据的 阅读全文
posted @ 2020-09-24 22:46 Mr.peter 阅读(1059) 评论(0) 推荐(1)
摘要: 数据定义 1.函数返回值问题: 在函数有多个返回值时,只要有⼀个返回值有名 称,那么其他返回值也⼀定要有名称 2.结构体的⽐较问题 : 结构体⽐较规则之⼀: 只有相同的类型的结构体才可以⽐较(1 结构体的属性类型, 2 属性的顺序) 结构体⽐较规则之⼆: 即使两个结构体的属性类型和顺序相同,但是⾥⾯ 阅读全文
posted @ 2020-09-24 22:40 Mr.peter 阅读(4056) 评论(0) 推荐(0)
摘要: Go modules 是 Go 语⾔的依赖解决⽅案,发布于 Go1.11,成⻓于 Go1.12,丰富于 Go1.13,正式于 Go1.14 推荐在⽣产上使⽤。 解决了什么问题 ? Go 语⾔⻓久以来的依赖管理问题。 “淘汰”现有的 GOPATH 的使⽤模式。 统⼀社区中的其它的依赖管理⼯具(提供迁移 阅读全文
posted @ 2020-09-22 17:16 Mr.peter 阅读(1827) 评论(0) 推荐(0)
摘要: 1.defer执行顺序:与调用顺序相反 2.defer和return :return先于defer执行 3.函数的返回值的初始化:函数的有名返回值,是在函数刚开始调用的时候初始化的,默认值是0,生命周期在函数作用域有效。 4.有名函数返回值遇见defer的情况:defer在return之后执行,返回 阅读全文
posted @ 2020-09-21 16:15 Mr.peter 阅读(228) 评论(0) 推荐(0)
摘要: Golang没有类(class),Go语言的结构体(struct)和其它编程语言的类(class)有同等的地位,你可以理解Golang是基于struct来实现OOP特性的。 Golang仍然有面向对象编程的继承,封装和多态的特性,只是实现的方式和其它OOP语言不一样,比如继承:Golang没有ext 阅读全文
posted @ 2020-09-21 16:12 Mr.peter 阅读(345) 评论(0) 推荐(0)
摘要: Go V1.3 之前的标记清除(mark and sweep) 流程: 第⼀步,暂停程序业务逻辑, 找出不可达的对象,和可达对象。 第⼆步, 开始标记,程序找出它所有可达的对象,并做上标记。 第三步, 标记完了之后,然后开始清除未标记的对象. 第四步, 停⽌暂停,让程序继续跑。然后循环重复这个过程, 阅读全文
posted @ 2020-09-18 16:45 Mr.peter 阅读(995) 评论(0) 推荐(0)
摘要: 变量的逃逸现象 将⼀个局部变量的地址返回给上层函数,依然能够访问,那么这个局 部变量产⽣的了逃逸现象,当前变量应该并没有分配到栈上。 new出来的变量是在“栈”还是“堆”? golang中的new,创建⼀个空间,未必是在堆上开辟的 结论:Golang中⼀个函数局部变量,不管是不是动态new出来的,还 阅读全文
posted @ 2020-09-18 16:40 Mr.peter 阅读(331) 评论(0) 推荐(0)
摘要: ⼀、Golang“调度器”由来 协程(co-routine), 引发的问题?(M:线程 N:协程) N:1 1.⽆法利⽤多个CPU 2.出现阻塞的瓶颈 1:1 1.跟多线程/多进程模型⽆异 2.切换协程成本代价昂贵 M:N 1.能够利⽤多核 2.过于依赖协程调度器的优化和算 法 go-routine 阅读全文
posted @ 2020-09-11 15:25 Mr.peter 阅读(870) 评论(0) 推荐(0)
上一页 1 ··· 39 40 41 42 43 44 45 46 47 ··· 108 下一页