Skip to content

Commit 959b69d

Browse files
committed
[utils/zipfiles.go]: 解决for循环中使用defer可能会造成的内存泄露问题
1 parent 9af429d commit 959b69d

File tree

1 file changed

+35
-24
lines changed

1 file changed

+35
-24
lines changed

server/utils/zipfiles.go

Lines changed: 35 additions & 24 deletions
Original file line numberDiff line numberDiff line change
@@ -13,51 +13,62 @@ import (
1313
//@param: filename string, files []string, oldform, newform string
1414
//@return: error
1515

16-
func ZipFiles(filename string, files []string, oldform, newform string) error {
16+
func ZipFiles(filename string, files []string, oldForm, newForm string) error {
1717

1818
newZipFile, err := os.Create(filename)
1919
if err != nil {
2020
return err
2121
}
22-
defer newZipFile.Close()
22+
defer func() {
23+
_ = newZipFile.Close()
24+
}()
2325

2426
zipWriter := zip.NewWriter(newZipFile)
25-
defer zipWriter.Close()
27+
defer func() {
28+
_ = zipWriter.Close()
29+
}()
2630

2731
// 把files添加到zip中
2832
for _, file := range files {
2933

30-
zipfile, err := os.Open(file)
34+
zipFile, err := os.Open(file)
3135
if err != nil {
3236
return err
3337
}
34-
defer zipfile.Close()
38+
err = func() error {
39+
defer func() {
40+
_ = zipFile.Close()
41+
}()
42+
// 获取file的基础信息
43+
info, err := zipFile.Stat()
44+
if err != nil {
45+
return err
46+
}
3547

36-
// 获取file的基础信息
37-
info, err := zipfile.Stat()
38-
if err != nil {
39-
return err
40-
}
48+
header, err := zip.FileInfoHeader(info)
49+
if err != nil {
50+
return err
51+
}
4152

42-
header, err := zip.FileInfoHeader(info)
43-
if err != nil {
44-
return err
45-
}
46-
47-
// 使用上面的FileInforHeader() 就可以把文件保存的路径替换成我们自己想要的了,如下面
48-
header.Name = strings.Replace(file, oldform, newform, -1)
53+
// 使用上面的FileInfoHeader() 就可以把文件保存的路径替换成我们自己想要的了,如下面
54+
header.Name = strings.Replace(file, oldForm, newForm, -1)
4955

50-
// 优化压缩
51-
// 更多参考see http://golang.org/pkg/archive/zip/#pkg-constants
52-
header.Method = zip.Deflate
56+
// 优化压缩
57+
// 更多参考see http://golang.org/pkg/archive/zip/#pkg-constants
58+
header.Method = zip.Deflate
5359

54-
writer, err := zipWriter.CreateHeader(header)
60+
writer, err := zipWriter.CreateHeader(header)
61+
if err != nil {
62+
return err
63+
}
64+
if _, err = io.Copy(writer, zipFile); err != nil {
65+
return err
66+
}
67+
return nil
68+
}()
5569
if err != nil {
5670
return err
5771
}
58-
if _, err = io.Copy(writer, zipfile); err != nil {
59-
return err
60-
}
6172
}
6273
return nil
6374
}

0 commit comments

Comments
 (0)