-
Go原生支持交叉编译到FreeBSD,仅限amd64和arm64架构(Go1.16起移除i386支持),需设GOOS=freebsd、GOARCH=amd64/arm64且CGO_ENABLED=0生成静态二进制;验证用file/ldd,注意ABI兼容性、noexec挂载及内核模块。
-
Go的json包默认将nil切片编码为null,而空切片[]T{}编码为[];若需保持RESTAPI合同一致性(如始终返回"addresses":[]),必须确保结构体字段初始化为空切片而非nil。
-
享元模式在Go中通过结构体封装不可变内部状态、工厂复用实例、剥离可变外部状态实现;用sync.Map缓存共享对象,按需传入外部参数,必要时结合sync.Pool减少GC压力。
-
sync.Map不适合MapReduce中间结果存储,因其在高频写入与遍历混合场景下性能退化,且缺乏原子性“写入并返回当前值”语义,易致reduce阶段漏数据或重复计算。
-
Go语言中atomic包提供原子操作以实现并发安全的共享变量读写,相比互斥锁更轻量。1.常见函数包括Add、Load、Store、Swap和CompareAndSwap,支持int32、int64等类型,确保操作不可中断。2.典型应用是使用atomic.AddInt64实现多goroutine下的计数器递增,避免数据竞争,保证最终结果正确。
-
Go的json.Unmarshal不会panic,非法JSON返回json.SyntaxError(含Offset定位),类型错误实为json.UnmarshalTypeError;需用errors.As捕获,避免字符串匹配,注意嵌套字段错误路径缺失、重复解析性能问题及部分解析导致的隐蔽错误。
-
原型模式通过已有对象创建新对象,在Go中利用结构体复制和接口实现。值复制为浅拷贝,含指针字段时需深拷贝避免数据共享。可通过定义Cloner接口统一克隆行为,复杂结构推荐手动实现Clone方法并递归处理嵌套对象;对于多层嵌套或动态结构,可使用gob序列化实现通用深拷贝,但性能较低,高频场景应手写优化。选择策略:简单结构直接赋值,关键业务手动克隆,临时需求用gob。
-
要显示allocs/op,必须同时使用-benchmem参数和在基准函数中调用b.ReportAllocs();allocs/op比B/op更关键,因其反映堆分配次数与GC压力。
-
Go的reflect包不支持直接将string类型的reflect.Value转换为int,因为Go类型系统禁止跨类别(如字符串→数字)的底层类型转换;必须借助strconv等标准库进行语义解析。
-
绝大多数业务写操作必须用db.Transaction而非手写Begin/Commit,因db.Begin()返回新事务实例tx,混用db会绕过事务直连数据库;tx提交或回滚后不可复用;db.Transaction仅捕获panic并回滚,不校验逻辑错误、不自动提交,易静默失败;嵌套事务实为SAVEPOINT;HTTP/缓存等I/O操作严禁入事务体,应移至tx.AfterCommit()或异步处理。
-
gRPC客户端默认不支持轮询或随机负载均衡,需显式启用round_robin或自定义balancer;必须通过dns:///resolver获取多地址,且Go1.21+需配置ServiceConfig。
-
引言大纲
这个月我会整理分享一系列后端工程师求职面试相关的文章,知识脉络图如下:
JAVA/GO/PHP 面试常问的知识点DB:MySql PgSqlCache: Redis MemCache MongoDB数据结构算法微服务&高并发流媒体WEB3.
-
1. Golint
(1)安装golint
git clone https://github.com/golang/lint.git
cd lint/golint
go install
(2)使用方式
# 检查单个文件
golint service.go
# 检查当前目录所有.go文件,不会递归查找
golint
(3)golint校验规则
-
一、格式化输入和输出
1.从终端获取用户的输入
fmt.Scanf 空格作为分隔符,占位符和格式化输出的一致
fmt.Scan 从终端获取用户的输入,存储在Scanln中的参数里,空格和换行符作为分隔符
fmt.Scanln
-
Go GRPC 入门
1,安装包
grpc
golang-grpc 包提供了 gRPC 相关的代码库,通过这个库我们可以创建 gRPC 服务或客户端,首先需要安装他。
go get -u google.golang.org/grpc
协议插件
要玩 gRPC,自然离不开 proto 文