php查看一個(gè)變量的占用內(nèi)存的實(shí)例代碼
事例:
php版本為7.2
<?phpecho memory_get_usage() , ’<br>’;$start = memory_get_usage();$a = Array();for ($i=0; $i<1000; $i++) {$a[$i] = $i + $i;}$mid = memory_get_usage();echo memory_get_usage() , ’<br>’;for ($i=1000; $i<2000; $i++) {$a[$i] = $i + $i;}$end = memory_get_usage();echo memory_get_usage() , ’<br>’;echo ’argv:’, ($mid - $start)/1000 ,’bytes’ , ’<br>’;echo ’argv:’,($end - $mid)/1000 ,’bytes’ , ’<br>’;echo ’Memory:’, ($mid - $start)/1024 ,’k’ , ’<br>’;echo ’Memory:’,($end - $mid)/1024 ,’k’ , ’<br>’;輸出是:389336418056442632argv:28.72bytesargv:24.576bytesMemory:28.046875kMemory:24k
返回當(dāng)前分配給你的 PHP 腳本的內(nèi)存量,單位是字節(jié)(byte)。
大概了解1000個(gè)元素的整數(shù)數(shù)組需要占用 28k 內(nèi)存,平均每個(gè)元素占用 28 個(gè)字節(jié)
memory_get_usage() 返回的結(jié)果并不是全是被數(shù)組占用了,還要包括一些 PHP
運(yùn)行本身分配的一些結(jié)構(gòu),可能用內(nèi)置函數(shù)生成的數(shù)組更接近真實(shí)的空間:
<?php$start = memory_get_usage();$a = array_fill(0, 10000, 1);$mid = memory_get_usage(); //10k elements array;echo ’argv:’, ($mid - $start )/10000,’byte’ , ’<br>’;echo ’Memory:’, ($mid - $start)/1024 ,’k’ , ’<br>’;$b = array_fill(0, 10000, 1);$end = memory_get_usage(); //10k elements array;echo ’argv:’, ($end - $mid)/10000 ,’byte’ , ’<br>’;echo ’Memory:’,($end - $mid)/1024 ,’k’ , ’<br>’;得到:argv:54.5792byteargv:54.5784byteargv:39.736byteMemory:388.046875kargv:39.736byteMemory:388.046875k
大概了解10000個(gè)元素的整數(shù)數(shù)組需要占用 388k 內(nèi)存 ,從這個(gè)結(jié)果來看似乎一個(gè)數(shù)組元素大約占用了39個(gè)字節(jié)左右。
內(nèi)容補(bǔ)充:
php獲取變量所占內(nèi)存大小的方法
$start_memory = memory_get_usage();$foo = 'Some variable';echo memory_get_usage() - $start_memory;
這個(gè)可以獲取所有變量類型的大小
strlen($foo) 這個(gè)可以獲取當(dāng)前字符串的字節(jié)大小 除以8就是位大小
到此這篇關(guān)于php查看一個(gè)變量的占用內(nèi)存的實(shí)例代碼的文章就介紹到這了,更多相關(guān)php怎么查看一個(gè)變量的占用內(nèi)存內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. el-input無法輸入的問題和表單驗(yàn)證失敗問題解決2. 不要在HTML中濫用div3. react腳手架配置代理的實(shí)現(xiàn)4. JavaScript中顏色模型的基礎(chǔ)知識(shí)與應(yīng)用詳解5. XML入門的常見問題(三)6. JavaScript快速實(shí)現(xiàn)一個(gè)顏色選擇器7. CSS3實(shí)例分享之多重背景的實(shí)現(xiàn)(Multiple backgrounds)8. 前端html+css實(shí)現(xiàn)動(dòng)態(tài)生日快樂代碼9. Jquery使用原生AJAX方法請求數(shù)據(jù)10. React實(shí)現(xiàn)一個(gè)倒計(jì)時(shí)hook組件實(shí)戰(zhàn)示例
