Я использую golang gzip.NewWriter
, чтобы сжать фрагмент , и defer Close()
, чтобы закрыть писатель. Но при чтении из заархивированных данных, он вернет unexpected EOF
. Код:
func main() {
a := []byte{'a', 'b', 'c', 'd', 'e', 'f'}
zippedData, err := zipData(a)
if err != nil {
panic(err)
}
unzippedData, err := unzipData(zippedData)
if err != nil {
panic(err)
}
fmt.Printf("%v\n", unzippedData)
}
Функция zip:
func zipData(originData []byte) ([]byte, error) {
var bf bytes.Buffer
gw := gzip.NewWriter(&bf)
defer gw.Close()
_, err := gw.Write(originData)
if err != nil {
return nil, errors.New(fmt.Sprintf("gzip data err: %v", err))
}
err = gw.Flush()
if err != nil {
return nil, err
}
// if I rm 'defer gw.Close()' and call 'gw.Close()' here, it'll be ok
logs.Debug("before gzip len: %v", len(originData))
logs.Debug("gzip len: %v", bf.Len())
return bf.Bytes(), nil
}
Выше функция zip использует defer gw.Close()
для закрытия gw.
Функция распаковки:
func unzipData(zippedData []byte) ([]byte, error) {
dst := make([]byte, len(zippedData))
copy(dst, zippedData)
reader, err := gzip.NewReader(bytes.NewBuffer(dst))
if err != nil {
return nil, errors.New(fmt.Sprintf("unzip err :%v", err))
}
defer reader.Close()
data, err := ioutil.ReadAll(reader)
if err != nil {
return nil, errors.New(fmt.Sprintf("read err :%v", err))
}
return data, err
}
Почему defer gw.Close()
чехлы unexpected EOF
?