runtime.GOMAXPROCS函數(shù)
通過runtime.GOMAXPROCS函數(shù)坑律,應(yīng)用程序何以在運行期間設(shè)置運行時系統(tǒng)中得P最大數(shù)量旷祸。但這會引起“Stop the Word”简识。所以,應(yīng)在應(yīng)用程序最早的調(diào)用梳猪。并且最好的設(shè)置P最大值的方法是在運行Go程序之前設(shè)置好操作程序的環(huán)境變量GOMAXPROCS,而不是在程序中調(diào)用runtime.GOMAXPROCS函數(shù)瘸右。
最后記住,無論我們傳遞給函數(shù)的整數(shù)值是什么值萍悴,運行時系統(tǒng)的P最大值總會在1~256之間头遭。
runtime.Goexit函數(shù)
runtime.Goexit函數(shù)被調(diào)用后,會立即使調(diào)用他的Groution的運行被終止癣诱,但其他Goroutine并不會受到影響计维。runtime.Goexit函數(shù)在終止調(diào)用它的Goroutine的運行之前會先執(zhí)行該Groution中還沒有執(zhí)行的defer語句。
runtime.Gosched函數(shù)
runtime.Gosched函數(shù)的作用是暫停調(diào)用他的Goroutine的運行撕予,調(diào)用他的Goroutine會被重新置于Gorunnable狀態(tài)鲫惶,并被放入調(diào)度器可運行G隊列中。
runtime.NumGoroutine函數(shù)
runtime.NumGoroutine函數(shù)在被調(diào)用后实抡,會返回系統(tǒng)中的處于特定狀態(tài)的Goroutine的數(shù)量欠母。這里的特指是指Grunnable\Gruning\Gsyscall\Gwaition。處于這些狀態(tài)的Groutine即被看做是活躍的或者說正在被調(diào)度吆寨。
注意:垃圾回收所在Groutine的狀態(tài)也處于這個范圍內(nèi)的話赏淌,也會被納入該計數(shù)器。
runtime.LockOSThread和runtime.UnlockOSThread函數(shù)
前者調(diào)用會使調(diào)用他的Goroutine與當(dāng)前運行它的M鎖定到一起啄清,后者調(diào)用會解除這樣的鎖定六水。
注意:
- 多次調(diào)用前者不會出現(xiàn)任何問題,但最后一次調(diào)用的記錄會被保留辣卒,
- 即時之前沒有調(diào)用前者掷贾,對后者的調(diào)用也不會產(chǎn)生任何副作用
debug.SetMaxStack函數(shù)
debug.SetMaxStack函數(shù)的功能是約束單個Groutine所能申請的棧空間的最大尺寸荣茫。
debug.SetMaxThreads函數(shù)
debug.SetMaxThreads函數(shù)的功能是對go語言運行時系統(tǒng)所使用的內(nèi)核線程的數(shù)量(確切的說是M的數(shù)量)進行設(shè)置
runtime.GC函數(shù)
會讓運行時系統(tǒng)進行一次強制性的垃圾收集胯盯,
- 強制的垃圾回收:不管怎樣,都要進行的垃圾回收计露。
- 非強制的垃圾回收:只會在一定條件下進行的垃圾回收(即運行時博脑,系統(tǒng)自上次垃圾回收之后新申請的堆內(nèi)存的單元(也成為單元增量)達到指定的數(shù)值)憎乙。
debug.SetGCPercent函數(shù)
用于設(shè)置一個比率(垃圾收集比率),前面所說的單元增量與前一次垃圾收集時的歲內(nèi)存的單元數(shù)量和此垃圾手機比率有關(guān)叉趣。
<觸發(fā)垃圾收集的堆內(nèi)存單元增量>=<上一次垃圾收集完的堆內(nèi)存單元數(shù)量>*(<垃圾收集比率>/100)