snappy.go 799 B

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. package conn
  2. import (
  3. "io"
  4. "github.com/cnlh/nps/lib/pool"
  5. "github.com/golang/snappy"
  6. )
  7. type SnappyConn struct {
  8. w *snappy.Writer
  9. r *snappy.Reader
  10. }
  11. func NewSnappyConn(conn io.ReadWriteCloser) *SnappyConn {
  12. c := new(SnappyConn)
  13. c.w = snappy.NewBufferedWriter(conn)
  14. c.r = snappy.NewReader(conn)
  15. return c
  16. }
  17. //snappy压缩写
  18. func (s *SnappyConn) Write(b []byte) (n int, err error) {
  19. if n, err = s.w.Write(b); err != nil {
  20. return
  21. }
  22. if err = s.w.Flush(); err != nil {
  23. return
  24. }
  25. return
  26. }
  27. //snappy压缩读
  28. func (s *SnappyConn) Read(b []byte) (n int, err error) {
  29. buf := pool.BufPool.Get().([]byte)
  30. defer pool.BufPool.Put(buf)
  31. if n, err = s.r.Read(buf); err != nil {
  32. return
  33. }
  34. copy(b, buf[:n])
  35. return
  36. }
  37. func (s *SnappyConn) Close() error {
  38. s.w.Close()
  39. return s.w.Close()
  40. }