2020. március 26., csütörtök 7:58:59 UTC+1 időpontban steve tang a 
következőt írta:
>
> 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> 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.
>> 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>
>>
>>
>>
1. sync.Pool MUST use pointers (*[]byte)
2. what is `chunkBuf := bufferpool.GetInstance().Get()` ? it must be an 
io.Writer, but you should Reset/Truncate it when you Put it back to the 
pool!

-- 
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/e6e65488-d105-4880-bc61-90dd0ee9c7e2%40googlegroups.com.

Reply via email to