想粗略地理解一個(gè)腳本消耗了多少內(nèi)存,或著在你往PowerShell中的變量存結(jié)果時(shí),消耗了多少內(nèi)存,可以借助于下面的函數(shù):
#requires -Version 2 $script:last_memory_usage_byte = 0 function Get-MemoryUsage{$memusagebyte = [System.GC]::GetTotalMemory('forcefullcollection')$memusageMB = $memusagebyte / 1MB$diffbytes = $memusagebyte - $script:last_memory_usage_byte$difftext = ''$sign = ''if ( $script:last_memory_usage_byte -ne 0 ){if ( $diffbytes -ge 0 ){$sign = '+'}$difftext = ", $sign$diffbytes"}Write-Host -Object ('Memory usage: {0:n1} MB ({1:n0} Bytes{2})' -f $memusageMB,$memusagebyte, $difftext) # save last value in script global variable$script:last_memory_usage_byte = $memusagebyte}
你可以在任何時(shí)候運(yùn)行Get-MemoryUsage,它會(huì)返回當(dāng)前腳本最后一次調(diào)用后消耗的內(nèi)存,同時(shí)和你上一次調(diào)用Get-MemoryUsage運(yùn)行結(jié)果的進(jìn)行對(duì)比,并顯示內(nèi)存的增量。
這里的關(guān)鍵點(diǎn)是使用了GC,它在.NET Framwwork中負(fù)責(zé)垃圾回收,通常不會(huì)立即釋放內(nèi)存,想要粗略地計(jì)算內(nèi)存消耗,垃圾回收器需要被指定釋放未被使用的內(nèi)存[gc]::Collect(),然后再統(tǒng)計(jì)分配的內(nèi)存。
為了更好的演示上面的函數(shù)我們來(lái)看一個(gè)調(diào)用的例子:
PS> Get-MemoryUsageMemory usage: 6.7 MB (6,990,328 Bytes)PS> $array = 1..100000PS> Get-MemoryUsageMemory usage: 10.2 MB (10,700,064 Bytes, +3709736)PS> Remove-Variable -Name arrayPS> Get-MemoryUsageMemory usage: 7.4 MB (7,792,424 Bytes, -2907640)
新聞熱點(diǎn)
疑難解答
圖片精選