-
本文主要介绍go语言静态库的编译和使用方法,以windows平台为例,linux平台步骤一样,具体环境如下:
>echo %GOPATH%
E:\share\git\go_practice\
>echo %GOROOT%
C:\Go\
>tree /F %GOPATH%\src
卷 work 的文件夹
-
个人常用函数
func IsContain(items []string, item string) bool {
for _, eachItem := range items {
if eachItem == item {
return true
}
}
return false
}
使用方法
var word := "my"
var sentence := []string{"my","word","in","a","sentenc
-
定义channel管道
定义一个channel时,也需要定义发送到管道的值类型。channel可以使用内置的make()函数来创建:
var ch = make(chan int) //等价于:make(chan Type,0)
var ch = make(chan Type,capacity)
channel管道塞值
-
阅读本文需要了解一些UNIX系统中信号的概念,请提前查阅资料预习。
优雅地关机
什么是优雅关机?
优雅关机就是服务端关机命令发出后不是立即关机,而是等待当前还在处理的请求全部处理
-
正常情况下,新激活的goroutine(协程)的结束过程是不可控制的,唯一可以保证终止goroutine(协程)的行为是main goroutine(协程)的终止。也就是说,我们并不知道哪个goroutine(协程)什么时候
-
答案:TCP服务器高并发性能调优需从系统配置、网络参数、I/O模型和应用架构入手。首先提升文件描述符和进程数限制,确保内存充足;其次调整TCP参数如启用TIME_WAIT重用、增大连接队列、优化缓冲区;选用epoll非阻塞IO与线程池或协程提升并发处理能力;应用层采用连接复用、高效编解码、负载均衡,并结合监控压测持续优化,最终实现高吞吐、低延迟、稳定服务。
-
应复用http.Client并调优Transport参数以提升并发性能,关键包括:使用全局客户端实例、配置MaxIdleConns和MaxIdleConnsPerHost、启用keep-alive、控制并发数及设置超时。
-
sync.Map不适合高并发写入,因其写新key需加锁升级dirtymap,导致热点key串行化;分片Map通过哈希隔离不同key的读写,显著降低锁竞争。
-
使用GoMock可实现依赖隔离,提升测试效率。通过mockgen生成接口的模拟对象,利用EXPECT设定期望行为,支持参数匹配与调用次数控制,确保逻辑正确性。
-
HTTP请求体直接读取大文件会OOM,因io.ReadAll等函数将整个文件加载进内存;multipart表单默认ParseMultipartForm会全量读入内存,需手动用multipart.Reader解析并禁用自动解析。
-
http.ListenAndServe是Go启动HTTP服务的核心函数,必须配对http.HandleFunc注册路由,且端口格式需为":8080";若仅注册未调用、端口错误或绑定127.0.0.1则导致启动失败、静默退出或外部无法访问。
-
OFFSET深翻变慢是因为MySQL需真实扫描并丢弃前10万行,I/O与CPU开销线性增长;应改用游标分页,配合唯一排序字段、覆盖索引、Redis缓存及严格分页限制。
-
用channel做事件总线易卡死,因其本质是点对点管道,不支持一对多广播:无缓冲时发送阻塞,有缓冲时满则丢事件,且无法动态增删监听者,导致deadlock或事件静默。
-
数组转切片可直接用[:]语法,共享底层数组;切片转数组需确保长度足够,推荐用copy安全转换,避免强制类型转换导致崩溃。
-
答案:channel和select组合可实现多路通信、超时控制与流程编排。1.select监听多个channel,优先处理最先就绪的case,适用于竞态场景如并行查询;2.结合time.After可设置超时,避免goroutine永久阻塞,提升程序健壮性。