2011-03-24 23:46:17 +00:00
|
|
|
// Copyright 2009 The Go Authors. All rights reserved.
|
|
|
|
// Use of this source code is governed by a BSD-style
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
|
|
|
package runtime
|
|
|
|
|
|
|
|
import "unsafe"
|
|
|
|
|
2012-02-09 08:19:58 +00:00
|
|
|
// A MemStats records statistics about the memory allocator.
|
|
|
|
type MemStats struct {
|
2011-03-24 23:46:17 +00:00
|
|
|
// General statistics.
|
|
|
|
Alloc uint64 // bytes allocated and still in use
|
|
|
|
TotalAlloc uint64 // bytes allocated (even if freed)
|
|
|
|
Sys uint64 // bytes obtained from system (should be sum of XxxSys below)
|
|
|
|
Lookups uint64 // number of pointer lookups
|
|
|
|
Mallocs uint64 // number of mallocs
|
|
|
|
Frees uint64 // number of frees
|
|
|
|
|
|
|
|
// Main allocation heap statistics.
|
2012-03-02 20:01:37 +00:00
|
|
|
HeapAlloc uint64 // bytes allocated and still in use
|
|
|
|
HeapSys uint64 // bytes obtained from system
|
|
|
|
HeapIdle uint64 // bytes in idle spans
|
|
|
|
HeapInuse uint64 // bytes in non-idle span
|
|
|
|
HeapReleased uint64 // bytes released to the OS
|
|
|
|
HeapObjects uint64 // total number of allocated objects
|
2011-03-24 23:46:17 +00:00
|
|
|
|
|
|
|
// Low-level fixed-size structure allocator statistics.
|
|
|
|
// Inuse is bytes used now.
|
|
|
|
// Sys is bytes obtained from system.
|
|
|
|
StackInuse uint64 // bootstrap stacks
|
|
|
|
StackSys uint64
|
|
|
|
MSpanInuse uint64 // mspan structures
|
|
|
|
MSpanSys uint64
|
|
|
|
MCacheInuse uint64 // mcache structures
|
|
|
|
MCacheSys uint64
|
|
|
|
BuckHashSys uint64 // profiling bucket hash table
|
|
|
|
|
|
|
|
// Garbage collector statistics.
|
2012-03-02 20:01:37 +00:00
|
|
|
NextGC uint64 // next run in HeapAlloc time (bytes)
|
|
|
|
LastGC uint64 // last run in absolute time (ns)
|
2011-03-24 23:46:17 +00:00
|
|
|
PauseTotalNs uint64
|
|
|
|
PauseNs [256]uint64 // most recent GC pause times
|
|
|
|
NumGC uint32
|
|
|
|
EnableGC bool
|
|
|
|
DebugGC bool
|
|
|
|
|
|
|
|
// Per-size allocation statistics.
|
|
|
|
// 61 is NumSizeClasses in the C code.
|
|
|
|
BySize [61]struct {
|
|
|
|
Size uint32
|
|
|
|
Mallocs uint64
|
|
|
|
Frees uint64
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-09-16 15:47:21 +00:00
|
|
|
var Sizeof_C_MStats uintptr // filled in by malloc.goc
|
2011-03-24 23:46:17 +00:00
|
|
|
|
2012-02-09 08:19:58 +00:00
|
|
|
var VmemStats MemStats
|
|
|
|
|
2011-03-24 23:46:17 +00:00
|
|
|
func init() {
|
2012-02-09 08:19:58 +00:00
|
|
|
if Sizeof_C_MStats != unsafe.Sizeof(VmemStats) {
|
|
|
|
println(Sizeof_C_MStats, unsafe.Sizeof(VmemStats))
|
2011-03-24 23:46:17 +00:00
|
|
|
panic("MStats vs MemStatsType size mismatch")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-02-09 08:19:58 +00:00
|
|
|
// ReadMemStats populates m with memory allocator statistics.
|
|
|
|
func ReadMemStats(m *MemStats)
|
2011-09-16 15:47:21 +00:00
|
|
|
|
2011-03-24 23:46:17 +00:00
|
|
|
// GC runs a garbage collection.
|
|
|
|
func GC()
|