Go语言中使用compress/gzip包实现文件及内存数据的压缩解压。1. 压缩文件:打开源文件,创建.gz目标文件,通过gzip.NewWriter写入并调用Close()完成压缩。2. 解压文件:用gzip.NewReader读取.gz文件,io.Copy将解压数据写入新文件。3. 内存操作:bytes.Buffer结合gzip.Writer/Reader实现字节流压缩解压,适用于API响应等场景。关键点:Writer必须Close以触发压缩,Reader可直接流式读取,建议封装为通用函数复用。

在Go语言中处理gzip压缩与解压非常方便,标准库compress/gzip结合os、io等包即可实现文件的压缩与解压。下面介绍常见使用场景和代码实践。
将普通文件压缩为gzip格式,通常用于日志归档或网络传输前的数据压缩。
关键步骤:
gzip.NewWriter包装输出文件Close()触发压缩完成func compressFile(src, dst string) error {
srcFile, err := os.Open(src)
if err != nil {
return err
}
defer srcFile.Close()
dstFile, err := os.Create(dst)
if err != nil {
return err
}
defer dstFile.Close()
gzWriter := gzip.NewWriter(dstFile)
defer gzWriter.Close()
_, err = io.Copy(gzWriter, srcFile)
return err
}
从gzip文件还原原始内容,常用于下载后解压或读取压缩日志。
立即学习“go语言免费学习笔记(深入)”;
注意点:
gzip.NewReader解析.gz文件func decompressFile(src, dst string) error {
srcFile, err := os.Open(src)
if err != nil {
return err
}
defer srcFile.Close()
gzReader, err := gzip.NewReader(srcFile)
if err != nil {
return err
}
defer gzReader.Close()
dstFile, err := os.Create(dst)
if err != nil {
return err
}
defer dstFile.Close()
_, err = io.Copy(dstFile, gzReader)
return err
}
适用于不需要落地文件的场景,比如API响应压缩或配置加载。
使用bytes.Buffer作为缓冲区:
// 压缩字节流
func gzipData(data []byte) ([]byte, error) {
var buf bytes.Buffer
writer := gzip.NewWriter(&buf)
_, err := writer.Write(data)
if err != nil {
return nil, err
}
writer.Close() // 必须调用
return buf.Bytes(), nil
}
// 解压字节流
func gunzipData(data []byte) ([]byte, error) {
reader, err := gzip.NewReader(bytes.NewReader(data))
if err != nil {
return nil, err
}
defer reader.Close()
return io.ReadAll(reader)
}
基本上就这些。核心是理解gzip.Writer需要显式关闭才能完成压缩流程,而gzip.Reader可直接用于流式读取。实际项目中可封装成通用函数复用。
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号