It is in line 899 and line 914 of the malloc.go file. 899 spc := makeSpanClass(sizeclass, noscan) 914 s = largeAlloc(size, needzero, noscan)
在 2019年1月27日星期日 UTC+8下午1:55:29,Ian Lance Taylor写道: > > On Sat, Jan 26, 2019 at 6:50 PM <mount...@gmail.com <javascript:>> wrote: > > > > I am looking at go1.11.1. > > I don't see a "noscan" flag for mallocgc in 1.11.1. There is a noscan > local variable, which is set of the type is passed as nil (the case I > mentioned earlier) or if the type has no pointers. > > > The memory allocation is still difficult to understand. What reference > materials can help me understand the context of this block? > > There is some information at golang.org/s/go14gc but I'm not sure it > quite covers what you are looking for. > > Ian > > > > 在 2019年1月27日星期日 UTC+8上午3:03:47,Ian Lance Taylor写道: > >> > >> On Sat, Jan 26, 2019 at 5:37 AM <mount...@gmail.com> wrote: > >> > > >> > Why the garbage collector won't know how to find the pointers? > >> > I looked at mallocgc and decided if the GC needs to scan this object > based on the noscan flag. > >> > >> What version of Go are you looking at? There was a flagNoScan as late > >> as Go 1.6, but there is no such flag in current versions of Go. > >> > >> Ian > >> > >> > 在 2019年1月25日星期五 UTC+8下午10:58:44,Ian Lance Taylor写道: > >> >> > >> >> On Thu, Jan 24, 2019 at 11:58 PM <mount...@gmail.com> wrote: > >> >> > > >> >> > go 1.11.1 source code is below: > >> >> > > >> >> > Generally speaking, make chan just pay attention to the presence > or absence of buf. > >> >> > > >> >> > When I saw the source code of make chan, I can understand case 1: > chan buf is 0, but can't understand case 2 & default. > >> >> > > >> >> > Who knows this principle? > >> >> > > >> >> > Thanks! > >> >> > > >> >> > var c *hchan > >> >> > switch { > >> >> > case size == 0 || elem.size == 0: > >> >> > // Queue or element size is zero. > >> >> > c = (*hchan)(mallocgc(hchanSize, nil, true)) > >> >> > // Race detector uses this location for synchronization. > >> >> > c.buf = c.raceaddr() > >> >> > case elem.kind&kindNoPointers != 0: > >> >> > // Elements do not contain pointers. > >> >> > // Allocate hchan and buf in one call. > >> >> > c = (*hchan)(mallocgc(hchanSize+uintptr(size)*elem.size, > nil, true)) > >> >> > c.buf = add(unsafe.Pointer(c), hchanSize) > >> >> > default: > >> >> > // Elements contain pointers. > >> >> > c = new(hchan) > >> >> > c.buf = mallocgc(uintptr(size)*elem.size, elem, true) > >> >> > } > >> >> > >> >> > >> >> First, let me say: please don't post screen shots. They are much > >> >> harder to read than ordinary text. I don't understand why anybody > >> >> ever posts screenshots of code, and I would be grateful for an > >> >> explanation. Thanks. > >> >> > >> >> What is happening in that code is that if the channel has a non-zero > >> >> buffer size, we need to allocate space to hold the elements in the > >> >> buffer. If the elements in the buffer do not contain any pointers, > we > >> >> can optimize by allocating the channel structure (hchan) and the > >> >> buffer in a single memory allocation. If the elements do contain > >> >> pointers, then that won't work, because the garbage collector won't > >> >> know how to find the pointers. So in that case we allocate the > hchan > >> >> struct and the buffer separately. Note the second argument to > >> >> mallocgc, which is the type of the memory being allocated. When > there > >> >> are no pointers, we pass nil, which tells the garbage collector that > >> >> the allocation contains no pointers. In the pointer case, we pass > the > >> >> element type. > >> >> > >> >> Ian > >> > > >> > -- > >> > 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...@googlegroups.com. > >> > For more options, visit https://groups.google.com/d/optout. > > > > -- > > 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...@googlegroups.com <javascript:>. > > For more options, visit https://groups.google.com/d/optout. > -- 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. For more options, visit https://groups.google.com/d/optout.