Thanks,  I used sync.Pool to allocate a byte.Buffer,  and response.Body  
isn't constant size in program, I find golang will grow the byte.Buffer 
space against to initial space. I changed code as follows:

type SyncPool struct{ Pool sync.Pool }

func (s *SyncPool) Get(n int) []byte {
   //比n大,不需要slice增长时,使用buffer pool
   if b, ok := s.Pool.Get().([]byte); ok && cap(b) >= n {
      return b[:n]
   } else {
      //miss size
      s.Put(b)
      return make([]byte, n)
   }
}

func (s *SyncPool) Put(b []byte) {
   s.Pool.Put(b)
}



const FourMB = 4 * 1024 * 1024

var pool = &SyncPool{
   sync.Pool{
      New: func() interface{} {
         return make([]byte, FourMB)
      },
   },
}




On Thursday, March 26, 2020 at 12:22:01 PM UTC+8, robert engels wrote:
>
> If the pool is a sync.Pool:
>
> Any item stored in the Pool may be removed automatically at any time without  
>   18  // notification. If the Pool holds the only reference when this 
> happens, the    19  // item might be deallocated.
>
> So placing an object in the pool does not guarantee it won’t be collected 
> - causing a future allocation.
>
> On Mar 25, 2020, at 10:22 PM, steve tang <tsg...@gmail.com <javascript:>> 
> wrote:
>
> chunkCrc32Hash := crc32.NewIEEE()
> chunkBuf := bufferpool.GetInstance().Get()
> //回收buffer
> defer bufferpool.GetInstance().Put(chunkBuf)
> writer := io.MultiWriter(chunkBuf, chunkCrc32Hash)
> _, copyErr := io.Copy(writer, chunkResp.RawResponse.Body)
> if copyErr != nil && copyErr != io.EOF {
>    logmgr.ErrorLogger(ctx, "fail to write chunk data to crc32 or buffer, 
> req: %s, err: %s", originReq.PrettyPrint(), copyErr)
>    return false, exception.OEFException(nil, 
> http.StatusInternalServerError, CopyChunkError, "internal server exception")
> }
>
> In above codes,  it writes chunk data to buffer pool, and the chunk data 
> size is 4MB.  When I used golang tool pprof to export memory pprof, there 
> about 8MB space has been allocated.  Could somebody help me why golang 
> allocated 
> memory space increases?
>
>
> <20200326-111844.png>
>
>
>
>
> -- 
> You received this message because you are subscribed to the Google Groups 
> "golang-nuts" group.
> To unsubscribe from this group and stop receiving emails from it, send an 
> email to golan...@googlegroups.com <javascript:>.
> To view this discussion on the web visit 
> https://groups.google.com/d/msgid/golang-nuts/6dbe93e6-9bb7-4112-87cb-085e68d9d393%40googlegroups.com
>  
> <https://groups.google.com/d/msgid/golang-nuts/6dbe93e6-9bb7-4112-87cb-085e68d9d393%40googlegroups.com?utm_medium=email&utm_source=footer>
> .
> <20200326-111844.png>
>
>
>

-- 
You received this message because you are subscribed to the Google Groups 
"golang-nuts" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to golang-nuts+unsubscr...@googlegroups.com.
To view this discussion on the web visit 
https://groups.google.com/d/msgid/golang-nuts/e3c0f5b2-700a-49eb-9593-b4f936bb93e1%40googlegroups.com.

Reply via email to