-
func (srv *Server) Serve(l net.Listener) error {
......
for {
rw, err := l.Accept()
if err != nil {
select {
case <-srv.getDoneChan():
return ErrServerClosed
default:
}
if ne, ok := err.(net.Error); ok && ne.Temporary()
-
牛顿法求平方根
原理
计算机常用循环来计算F的平方根.从某个猜测的x值开始,根据x^2与F的近似度来调整x,产生一个更好的猜测:
x -= (x * x - F) / (2 * x)
重复调整过程,猜测的结果会越来越精确,得到
-
我就废话不多说了,大家还是直接看代码吧~
package main
import (
"fmt"
"github.com/garyburd/redigo/redis"
)
func main() {
// 连接redis数据库,指定数据库的IP和端口
conn, err := redis.Dial("tcp", "36.99.16.197:6379")
if e
-
一、数组和切片的区别是什么?
1.数组
数组是内置(build-in)类型,是一组同类型数据的集合,它是值类型,通过从0开始的下标索引访问元素值。在初始化后长度是固定的,无法修改其长度。当作
-
闭包与defer
1.闭包
闭包 : 一个函数与其相关的引用环境组合的一个实体,其实可以理解为面向对象中类中的属性与方法。如代码块中,函数function的返回值(匿名函数)与变量n就是1个闭包。该匿
-
Go网络请求优化需复用连接、控制并发、设置超时、选合适协议:自定义http.Client调优Transport参数,用context设分级超时,限流防压垮,内部通信优先gRPC,避免JSON解析瓶颈。
-
能部署多个Go长连接服务,但须避免端口冲突、网络隔离失效和资源争抢;需通过环境变量与命令行参数动态指定监听地址、使用自定义bridge网络、监听0.0.0.0而非127.0.0.1,并配合TCP级健康检查与连接保活机制。
-
http.FileServer不适用于大文件上传下载,因其无流式控制、内存占用高、不支持断点续传与并发限速;需用multipart.Reader流式解析并os.File追加写入,配合io.CopyN或带缓冲的io.Copy控制内存与吞吐。
-
Go函数参数默认值传递,修改外部变量需传指针:形参声明为T,调用时传&变量,函数内用x赋值;结构体指针更高效且语义清晰;nil指针必须检查;切片/map/channel修改内容无需指针,但替换整个变量需指针。
-
当WebSocket接口返回的JSON中,某个字段(如args[0])本身是经过JSON编码的字符串(即“JSON-in-JSON”),需分两步解码:先解析外层结构,再对内层字符串单独调用json.Unmarshal。直接替换引号或反斜杠易破坏合法转义,不可靠。
-
close()只能由发送方调用,否则panic;关闭后读取返回零值且ok为false;重复close会panic;len/cap与关闭无关,判断是否关闭只能用<-ch,ok。
-
recover()只能在同Goroutine的defer中捕获本Goroutine的panic,因各Goroutine调用栈独立;需在出问题的Goroutine内用deferrecover(),或用errgroup.Group、带缓冲channel统一处理错误。
-
Go语言调用短信API需安全封装:用自定义http.Client设超时,分网络/HTTP/业务三类错误处理,敏感信息外置注入,客户端限流+去重+有节制重试。
-
Go多返回值是核心机制而非语法糖,需显式接收全部值或用_丢弃,命名返回值适用于错误统一或defer修改场景,调用方应立即检查error,避免struct或interface{}替代而破坏类型安全与可读性。
-
Read必须返回n,err以遵守io.Reader契约:n==0且err==nil会被上层误判为“未读完而重试”,导致死循环;EOF必须返回n==0且err==io.EOF,临时错误需返回n>=0且err!=nil(非io.EOF);禁止panic替代err;len(p)==0时可合法返回n==0,err==nil。