當前位置: 首頁>>代碼示例>>Golang>>正文


Golang debug.FreeOSMemory函數代碼示例

本文整理匯總了Golang中runtime/debug.FreeOSMemory函數的典型用法代碼示例。如果您正苦於以下問題:Golang FreeOSMemory函數的具體用法?Golang FreeOSMemory怎麽用?Golang FreeOSMemory使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。


在下文中一共展示了FreeOSMemory函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。

示例1: deriveKey

// deriveKey fills out the Key field.
func (sk *SecretKey) deriveKey(password *[]byte) error {
	key, err := scrypt.Key(*password, sk.Parameters.Salt[:],
		sk.Parameters.N,
		sk.Parameters.R,
		sk.Parameters.P,
		len(sk.Key))
	if err != nil {
		return err
	}
	copy(sk.Key[:], key)
	zero.Bytes(key)

	// I'm not a fan of forced garbage collections, but scrypt allocates a
	// ton of memory and calling it back to back without a GC cycle in
	// between means you end up needing twice the amount of memory.  For
	// example, if your scrypt parameters are such that you require 1GB and
	// you call it twice in a row, without this you end up allocating 2GB
	// since the first GB probably hasn't been released yet.
	debug.FreeOSMemory()

	// I'm not a fan of forced garbage collections, but scrypt allocates a
	// ton of memory and calling it back to back without a GC cycle in
	// between means you end up needing twice the amount of memory.  For
	// example, if your scrypt parameters are such that you require 1GB and
	// you call it twice in a row, without this you end up allocating 2GB
	// since the first GB probably hasn't been released yet.
	debug.FreeOSMemory()

	return nil
}
開發者ID:decred,項目名稱:dcrwallet,代碼行數:31,代碼來源:snacl.go

示例2: FreeMemory

// Starts another thread to perform OS memory freeing
func FreeMemory(durationMinutes int) {
	go func() {
		for {
			debug.FreeOSMemory()
			debug.FreeOSMemory()
			time.Sleep(time.Duration(durationMinutes) * time.Minute)
		}
	}()
}
開發者ID:infoassure,項目名稱:nsrls,代碼行數:10,代碼來源:misc.go

示例3: write

func write(wr writeRequest, id string) {
	cmds, idArr, bufTypeArr := createCommands(wr, id)

	qr := qReport{
		Cmd: "Queued",
		//Type: bufTypeArr,
		Ids:  idArr,
		D:    cmds,
		QCnt: wr.p.itemsInBuffer,
		Port: wr.p.portConf.Name,
	}
	json, _ := json.Marshal(qr)
	h.broadcastSys <- json

	// now send off the commands to the appropriate channel
	for index, cmdToSendToChannel := range cmds {
		//cmdIdCtr++
		//cmdId := "fakeid-" + strconv.Itoa(cmdIdCtr)
		cmdId := idArr[index]
		if bufTypeArr[index] == "Buf" {
			log.Println("Send was normal send, so sending to wr.p.sendBuffered")
			wr.p.sendBuffered <- Cmd{cmdToSendToChannel, cmdId, false, false}
		} else {
			log.Println("Send was sendnobuf, so sending to wr.p.sendNoBuf")
			wr.p.sendNoBuf <- Cmd{cmdToSendToChannel, cmdId, true, false}
		}
	}

	// garbage collect
	if *gcType == "max" {
		debug.FreeOSMemory()
	}

}
開發者ID:ndoty,項目名稱:serial-port-json-server,代碼行數:34,代碼來源:serial.go

示例4: fillseq

func fillseq() {
	dbname := os.Args[0] + ".db"
	f, err := os.OpenFile(dbname, os.O_CREATE|os.O_EXCL|os.O_RDWR, 0666)
	if err != nil {
		log.Fatal(err)
	}

	defer func() {
		f.Close()
		os.Remove(f.Name())
	}()

	filer := lldb.NewSimpleFileFiler(f)
	a, err := lldb.NewAllocator(filer, &lldb.Options{})
	if err != nil {
		log.Println(err)
		return
	}

	a.Compress = true
	b, _, err := lldb.CreateBTree(a, nil)
	if err != nil {
		log.Println(err)
		return
	}

	var keys [N][16]byte
	for i := range keys {
		binary.BigEndian.PutUint32(keys[i][:], uint32(i))
	}

	debug.FreeOSMemory()
	t0 := time.Now()
	for _, key := range keys {
		if err = b.Set(key[:], value100); err != nil {
			log.Println(err)
			return
		}
	}
	if err := filer.Sync(); err != nil {
		log.Println(err)
		return
	}
	var ms runtime.MemStats
	runtime.ReadMemStats(&ms)

	d := time.Since(t0)
	fi, err := f.Stat()
	if err != nil {
		log.Println(err)
		return
	}

	secs := float64(d/time.Nanosecond) / float64(time.Second)
	sz := fi.Size()
	fmt.Printf("fillseq      :%19v/op;%7.1f MB/s (%g secs, %d bytes)\n", d/N, float64(sz)/secs/1e6, secs, sz)
	nn, bytes := bufs.GCache.Stats()
	fmt.Printf("%d %d\n", nn, bytes)
	fmt.Printf("%+v\n", ms)
}
開發者ID:rfistman,項目名稱:camlistore,代碼行數:60,代碼來源:main.go

示例5: TestPartGC

func (s *MultipartTestSuite) TestPartGC() {
	part := NewPart()
	wrapper := NewDataWrapper()
	part.SetContentObject(wrapper)
	s.part.AddPart(part)

	allParts := s.part.GetPart(0)
	allParts2 := s.part.GetPart(0)

	_, ok := allParts.(Part)
	_, ok = allParts2.(Part)

	allParts = nil
	part = nil
	wrapper = nil
	debug.FreeOSMemory()

	// Try to access allParts2.
	// This should not fail under valgrind
	typeString := "multipart/mixed"
	boundary := "--foo++bar==foo--"
	contentType := NewContentTypeFromString(typeString)
	contentType.SetParameter("boundary", boundary)
	allParts2.SetContentType(contentType)

	assert.True(s.T(), ok)
}
開發者ID:partkyle,項目名稱:go-gmime,代碼行數:27,代碼來源:multipart_test.go

示例6: benchmarkPrev

func benchmarkPrev(b *testing.B, n int) {
	t := TreeNew(cmp)
	for i := 0; i < n; i++ {
		t.Set(i, 0)
	}
	debug.FreeOSMemory()
	b.ResetTimer()
	for i := 0; i < b.N; i++ {
		en, err := t.SeekLast()
		if err != nil {
			b.Fatal(err)
		}

		m := 0
		for {
			if _, _, err = en.Prev(); err != nil {
				break
			}
			m++
		}
		if m != n {
			b.Fatal(m)
		}
	}
}
開發者ID:nikandfor,項目名稱:b,代碼行數:25,代碼來源:all_test.go

示例7: gcRunner

//
// for test only, run GC for profile GC in huge map
func (eng *Engine) gcRunner(interval int) {
	tk := time.NewTicker(time.Duration(interval) * time.Second)
	defer tk.Stop()
	var pre, cnt int64
	var iopre, iocnt int64
	var rwpre, rwcnt int64
	var norepeatgc bool
	for {
		//
		cnt = atomic.LoadInt64(eng.aliveCount)
		iocnt = atomic.LoadInt64(eng.newCount)
		rwcnt = atomic.LoadInt64(eng.rwCount)
		if cnt > 0 {
			if eng.conf.gctest && (pre != cnt || iopre != iocnt || rwpre != rwcnt) {
				fmt.Printf("GC with %d connections.\n", cnt)
				runtime.GC()
				//fmt.Printf("GC done.\n")
				pre = cnt
			}
			norepeatgc = false
		} else if norepeatgc == false {
			// even if eng.conf.gctest == false, still call FreeOSMemory when connections == 0
			norepeatgc = true
			fmt.Printf("FreeOSMemory with %d connections.\n", cnt)
			// free memory
			debug.FreeOSMemory()
			//fmt.Printf("FreeOSMemory done.\n")
			pre = cnt
		}
		<-tk.C
	}
}
開發者ID:jmptrader,項目名稱:tcpengine,代碼行數:34,代碼來源:tcpengine.go

示例8: benchmarkNext

func benchmarkNext(b *testing.B, n int) {
	t := TreeNew(cmp)
	for i := int64(0); i < int64(n); i++ {
		t.Set(i, struct{}{})
	}
	debug.FreeOSMemory()
	b.ResetTimer()
	for i := 0; i < b.N; i++ {
		en, err := t.SeekFirst()
		if err != nil {
			b.Fatal(err)
		}

		m := 0
		for {
			if _, _, err = en.Next(); err != nil {
				break
			}
			m++
		}
		if m != n {
			b.Fatal(m)
		}
	}
	b.StopTimer()
	t.Close()
}
開發者ID:JesseLivingston,項目名稱:cayley,代碼行數:27,代碼來源:keys_test.go

示例9: monitor

func monitor() {
	c := time.Tick(1 * time.Second)
	mem := new(runtime.MemStats)
	origPct := debug.SetGCPercent(100)
	debug.SetGCPercent(origPct)
	for _ = range c {
		runtime.ReadMemStats(mem)
		mu.Lock()
		defer mu.Unlock()
		if tSize < 0 {
			continue
		}
		// Occupancy fraction: 70%. Don't GC before hitting this.
		softLimit := float64(tSize) * 0.7
		pct := softLimit / float64(mem.Alloc) * 100
		fmt.Printf("gctune: pct: %0.5f, target: %d, softLimit: %0.2f, Alloc: %d, Sys: %d\n", pct, tSize, softLimit, mem.Alloc, mem.Sys)
		if pct < 50 {
			// If this is too low, GC frequency increases too much.
			pct = 50
		}
		debug.SetGCPercent(int(pct))
		if mem.Sys > uint64(tSize*70/100) {
			fmt.Println("freeing")
			debug.FreeOSMemory()
		}
	}
}
開發者ID:nictuku,項目名稱:gctune,代碼行數:27,代碼來源:gctune.go

示例10: receiveDecrypt

func receiveDecrypt(conn net.Conn) (Message, error) {
	// Our work is:
	// (receive) -> [de-GOB] -> [DECRYPT] -> [de-GOB] -> msg

	// Receive data and de-serialize to get the encrypted message
	encMsg := new([]byte)
	receive := gob.NewDecoder(conn)
	if err := receive.Decode(encMsg); err != nil {
		return Message{}, err
	}

	// Create decrypter and pass it the encrypted message
	r := bytes.NewReader(*encMsg)
	decrypter, err := saltsecret.NewReader(r, conf.Key, saltsecret.DECRYPT, false)
	if err != nil {
		return Message{}, err
	}

	// Read unencrypted serialized message and de-serialize it
	msg := new(Message)
	dec := gob.NewDecoder(decrypter)
	if err = dec.Decode(msg); err != nil {
		return Message{}, err
	}
	debug.FreeOSMemory()
	return *msg, nil
}
開發者ID:andmarios,項目名稱:bashistdb,代碼行數:27,代碼來源:encryptcomm_lowmem.go

示例11: encryptDispatch

func encryptDispatch(conn net.Conn, m Message) error {
	// We want to sent encrypted data.
	// In order to encrypt, we need to first serialize the message.
	// In order to sent/receive hassle free, we need to serialize the encrypted message
	// So: msg -> [GOB] -> [ENCRYPT] -> [GOB] -> (dispatch)

	// Create encrypter
	var encMsg bytes.Buffer
	encrypter, err := saltsecret.NewWriter(&encMsg, conf.Key, saltsecret.ENCRYPT, true)
	if err != nil {
		return err
	}

	// Serialize message
	enc := gob.NewEncoder(encrypter)
	if err = enc.Encode(m); err != nil {
		return err
	}

	// Flush encrypter to actuall encrypt the message
	if err = encrypter.Flush(); err != nil {
		return err
	}

	// Serialize encrypted message and dispatch it
	dispatch := gob.NewEncoder(conn)
	if err = dispatch.Encode(encMsg.Bytes()); err != nil {
		return err
	}
	debug.FreeOSMemory()
	return nil
}
開發者ID:andmarios,項目名稱:bashistdb,代碼行數:32,代碼來源:encryptcomm_lowmem.go

示例12: cmpStat

func (cmc *FileMonitor) cmpStat(f_old map[string]os.FileInfo, f_new map[string]os.FileInfo) {
	var fo FileOp
	for i, v := range f_old {
		if in, ok := f_new[i]; ok {
			if !v.ModTime().Equal(in.ModTime()) {
				// update
				f_old[i] = in
				delete(f_new, i)
				fo.fname = i
				fo.op = OP_MOD
				cmc.f <- fo
			}
			delete(f_new, i)
			// no changed
		} else {
			delete(f_old, i)
			fo.fname = i
			fo.op = OP_DEL
			cmc.f <- fo
			// delete
		}
	}

	for i, v := range f_new {
		// add
		f_old[i] = v
		delete(f_new, i)
		fo.fname = i
		fo.op = OP_ADD
		cmc.f <- fo
	}
	debug.FreeOSMemory()
}
開發者ID:hwch,項目名稱:fmonitor,代碼行數:33,代碼來源:fmonitor.go

示例13: removeConnection

func (chat *Chat) removeConnection(toRemove *Connection) {
	for i, el := range chat.connections {
		if *toRemove == el {
			//chat.connections = append(chat.connections[:i], chat.connections[i+1:]...)

			// THE FOLLOWING IS UNNECESSARILY COMPLEX AND ONLY TO RULE OUT A MemLeak
			copy(chat.connections[i:], chat.connections[i+1:])
			chat.connections[len(chat.connections)-1] = Connection{} //nil // or the zero value of T
			chat.connections = chat.connections[:len(chat.connections)-1]

			// THE FOLLOWING IS UNNECESSARILY COMPLEX AND ONLY TO RULE OUT A MemLeak
			if cap(chat.connections) > 2*len(chat.connections) {
				fmt.Println("SHRINK")
				shrink := make([]Connection, len(chat.connections))
				copy(shrink, chat.connections)
				chat.connections = shrink
				debug.FreeOSMemory()
			}

			break
		}
	}
	// DEBUG::
	fmt.Println("Num GoRoutines", runtime.NumGoroutine())
	fmt.Println("Len(connections)", len(chat.connections))
	fmt.Println("Cap(connections)", cap(chat.connections))
	GoRuntimeStats()
}
開發者ID:SittingIdle,項目名稱:chat,代碼行數:28,代碼來源:engine.go

示例14: TestDispositionIsAttachment

func TestDispositionIsAttachment(t *testing.T) {
	loop := 1
	for i := 0; i < loop; i++ {
		// Case 1: not an attachment
		contentString := ""
		cd := NewContentDispositionFromString(contentString)
		assert.False(t, cd.IsAttachment())

		// Case 2: is an attachment
		contentString = "attachment"
		cd = NewContentDispositionFromString(contentString)
		assert.True(t, cd.IsAttachment())

		// Case 3: is an inline attachment
		contentString = "inline"
		cd = NewContentDispositionFromString(contentString)
		assert.True(t, cd.IsAttachment())

		// Case 4: anything is an attachment for now
		contentString = "bogus"
		cd = NewContentDispositionFromString(contentString)
		assert.True(t, cd.IsAttachment())
	}
	debug.FreeOSMemory()
}
開發者ID:partkyle,項目名稱:go-gmime,代碼行數:25,代碼來源:content_disposition_test.go

示例15: RebalanceGC

// RebalanceGC rebalances the tree and runs the garbage collector.
func (st *SimpleTree) RebalanceGC() *SimpleTree {
	st.Rebalance()
	runtime.GC()
	debug.FreeOSMemory()

	return st
}
開發者ID:teh-cmc,項目名稱:freetree,代碼行數:8,代碼來源:simpletree.go


注:本文中的runtime/debug.FreeOSMemory函數示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。