不太懂的API
persistentalloc
sysAlloc
mfixalloc.go
// 固定大小的对象分配器。 返回的内存未归零。
//
// See malloc.go for overview.
package runtime
import "unsafe"
//FixAlloc是用于固定大小对象的简单自由列表分配器。
//Malloc使用包裹在sysAlloc周围的FixAlloc来管理其MCache和MSpan对象。
//FixAlloc_Alloc返回的内存未归零。
//调用方负责锁定FixAlloc调用。
//调用者可以将状态保留在对象中,但通过释放和重新分配可以粉碎第一个单词。
type fixalloc struct {
size uintptr
first unsafe.Pointer // go func(unsafe.pointer, unsafe.pointer); f(arg, p) called first time p is returned, 对内存进行初始化
arg unsafe.Pointer
list *mlink // 缓存释放数据
chunk *byte // 每次申请64K数据
nchunk uint32 // trunk剩余数据大小
inuse uintptr // 使用中的数据
stat *uint64
}
type mlink struct {
next *mlink
}
func fixAlloc_Init(f *fixalloc, size uintptr, first func(unsafe.Pointer, unsafe.Pointer), arg unsafe.Pointer, stat *uint64) {
f.size = size
f.first = *(*unsafe.Pointer)(unsafe.Pointer(&first))
f.arg = arg
f.list = nil
f.chunk = nil
f.nchunk = 0
f.inuse = 0
f.stat = stat
}
func fixAlloc_Alloc(f *fixalloc) unsafe.Pointer {
if f.size == 0 {
print("runtime: use of FixAlloc_Alloc before FixAlloc_Initn")
throw("runtime: internal error")
}
if f.list != nil {
v := unsafe.Pointer(f.list)
f.list = f.list.next
f.inuse += f.size
return v
}
if uintptr(f.nchunk) < f.size {
f.chunk = (*uint8)(persistentalloc(_FixAllocChunk, 0, f.stat))
f.nchunk = _FixAllocChunk
}
v := (unsafe.Pointer)(f.chunk)
if f.first != nil {
fn := *(*func(unsafe.Pointer, unsafe.Pointer))(unsafe.Pointer(&f.first))
fn(f.arg, v)
}
f.chunk = (*byte)(add(unsafe.Pointer(f.chunk), f.size))
f.nchunk -= uint32(f.size)
f.inuse += f.size
return v
}
func fixAlloc_Free(f *fixalloc, p unsafe.Pointer) {
f.inuse -= f.size
v := (*mlink)(p)
v.next = f.list
f.list = v
}
有疑问加站长微信联系(非本文作者)