摘要:發(fā)現(xiàn)內(nèi)存泄漏打開的任務(wù)管理器,確保列有顯示。如果線圖不停的上升,就說明出現(xiàn)了內(nèi)存泄漏。定位內(nèi)存泄漏在開發(fā)者工具的面板中,我們可以選擇,記錄一個當(dāng)前頁面具體內(nèi)存使用情況的快照。如果該對象的增長了,說明確實(shí)出現(xiàn)了內(nèi)存泄漏。
網(wǎng)絡(luò) Network 瀑布流
隨著網(wǎng)頁的加載,每個HTTP請求都會是瀑布流中的一條。第一條都是文件document的加載,當(dāng)文件被解析,隨后通常是CSS文件的加載。和寫在HTML文件中的標(biāo)簽中的順序是一樣的。但瀏覽器會做一些優(yōu)化,比如會降低圖片的優(yōu)先度,提升CSS文件的優(yōu)先度等。
在瀑布流下方的表格中,我們可以看到請求的Name,Status,Type等信息。Initiator列的意思是,什么文件需求加載了這一行的文件。按住Shift點(diǎn)擊表格的一行,調(diào)用該行文件的相應(yīng)文件會變綠(who called it?),該行文件調(diào)用的相應(yīng)行會變紅(who does it called?)。
瀑布流顏色白色 隊(duì)列中。不常見。HTTP1中,瀏覽器一次性只能進(jìn)行6個TCP連接,比如我們有7個CSS文件,那么其中的一個就會在隊(duì)列中。
灰色 一個請求能發(fā)送前的各種停滯反應(yīng)時(shí)間。
淺灰色 在Proxy代理服務(wù)器消耗的時(shí)間
深綠色 DNS查找的時(shí)間
橙色 建立連接時(shí)間。包括TCP握手時(shí)間和建立SSL連接時(shí)間。
棕色 SSL連接時(shí)間
綠色 等待回復(fù)的時(shí)間。也就是等待獲得第一個字節(jié)的時(shí)間。如果綠色很長說明應(yīng)用服務(wù)器很慢。
藍(lán)色 下載回復(fù)內(nèi)容的時(shí)間。和文件大小有關(guān)系。
快照如果我們點(diǎn)擊Capture Screenshot按鈕,重新加載頁面, 就可以看到網(wǎng)頁的每次repaint,也就是網(wǎng)頁是如何加載的。
使用這個功能,我們可以知道在慢速網(wǎng)絡(luò)下,網(wǎng)頁是如何呈現(xiàn)出來的。
過濾信息Network面板中,我們可以點(diǎn)擊文件類型來查看特定類型的文件。左側(cè)有個輸入框也可以輸入特定條件。比如larger-than:200px,就可以觀察大于200px的圖片請求。
Disable Cache,Offline,Preserve Log三個按鈕的功能是顯而易見的。
性能 Performance 開發(fā)者性能VS用戶端性能測試開發(fā)者性能測試是在開發(fā)環(huán)境中做性能測試,但是用戶端是在真實(shí)用戶使用的情況下記錄測試數(shù)據(jù)。以前是這么做的:
const start = new Date().getTime(); const end = new Date().getTime(); const time = end - start;
這樣我們就可以記錄下用戶作出一個操作的時(shí)間,然后將數(shù)據(jù)post回來。
后來有了Performance API:
performance.mark("start") performance.mark("end); performance.measure("Our Measurement,"start","end"); performance.getEntriesByType("measure")圖片性能
一般圖片過大的解決方法:
resize圖片
刪除圖片的meta data
在服務(wù)器端使用gzip,brotli, zopfli等工具。
還有一個HTML API要知道,srcset
可以在不同窗口大小的時(shí)候加載指定的圖片。
但是為了瀏覽器兼容性,我們總是應(yīng)該給默認(rèn)的src attribute留一個URL。
頁面卡頓 Page Jank 為什么看起來卡現(xiàn)代大多數(shù)屏幕刷新率都是60幀每秒。1秒/60 = 16.66毫秒。所以我們的一個畫面更新的處理時(shí)間如果超過了16毫秒,就感覺卡。
編譯時(shí)間慢有一種卡的原因是因?yàn)?,解析Javascript的時(shí)間過長。V8引擎渲染頁面的時(shí)候,需要編譯Javascript,生成AST(Abstract Syntax Tree)。當(dāng)客戶端的處理性能很差的時(shí)候,就要等很久。
布局抖動還有一種卡的原因是因?yàn)椋琇ayout thrashing,反復(fù)布局,又稱布局抖動。
//Read const h1 = element.clientHeight; //Write element1.style.height = (h1 * 2) + "px"; //Read const h2 = element2.clientHeight; //Write element2.sytle.height = (h2 * 2) + "px";
當(dāng)我們反復(fù)進(jìn)行這種DOM讀寫操作的時(shí)候,就會造成布局抖動。
requestAnimationFrame如果我們可以將讀和寫完全分開,一次性操作所有讀,一次性操作所有寫,就不會有這種情況,但是這是不現(xiàn)實(shí)的。這就是使用window.requestAnimationFrame()的原因。
簡單說requestAnimationFrame將讀寫操作和屏幕刷新率匹配起來,當(dāng)瀏覽器準(zhǔn)備好更新下一幀時(shí),做想做的操作,減少性能浪費(fèi),避免跳幀。關(guān)于這個話題有很多寫Event Loop的文章里也有寫,這里不多寫。
觀察頁面重繪情況在開發(fā)者工具中,我們在更多工具中可以找到Rendering的選項(xiàng)。
打開這個選項(xiàng),頁面每次repaint的地方都會變成綠色,幫助開發(fā)者觀察是否一些沒必要重繪的地方在不停的被重繪,浪費(fèi)性能。
錄制操作和分析我們點(diǎn)擊錄制按鈕,在頁面上做一些操作,比如Scroll。Performance面板中就會有一些數(shù)據(jù)。
最下方有一個餅狀圖是一個概括總結(jié)。
展開Main行,X軸代表處理時(shí)間,Y軸是Call Stack。Y軸高沒關(guān)系,只是函數(shù)之間不斷的調(diào)用,但是如果有色塊很寬的話就說明處理時(shí)間很長。
我們可以使用WASD來操作。按W Zoom In可以看到具體信息。
找到一個很寬的色塊,看之前是哪個色塊調(diào)用了這個色塊,然后我們就可以在下方Summary面板中找到具體文件名,點(diǎn)擊去Sources面板看代碼。
內(nèi)存 Memory JS中的內(nèi)存泄漏當(dāng)一些內(nèi)存沒有按開發(fā)者的意愿被釋放的時(shí)候,就出現(xiàn)了內(nèi)存泄漏。
常見的內(nèi)存泄漏情況意外添加的全局變量
function foo() { bar = "Hi" }
當(dāng)foo被調(diào)用的時(shí)候,因?yàn)閎ar沒有變量聲明關(guān)鍵詞const, var, let。JS就會一直向上找這個變量到全局作用域,然后會為你創(chuàng)建一個全局變量bar。當(dāng)這個函數(shù)結(jié)束的時(shí)候,你以為這個bar會被回收,但其實(shí)它一直留在全局。設(shè)想如果這個bar不是“Hi”而是一個擁有很多元素的array,它留在了全局作用域,這并不是我們想要的情況。
沒有取消的計(jì)時(shí)器
顧名思義,計(jì)時(shí)器沒有被取消或移除。
多余的DOM元素變量
const button = document.getElementById("button); document.body.removeChild( document.getElementById("button) ); }
這里我們在DOM中移除了這個button,但是之前指向這個元素的reference還在,就是變量button。所以這個reference就留在了內(nèi)存中。
發(fā)現(xiàn)內(nèi)存泄漏打開Chrome的任務(wù)管理器,確保Javascript Memory列有顯示。我們可以看到每個標(biāo)簽頁的內(nèi)存使用情況。如果有一個標(biāo)簽頁的內(nèi)存使用不穩(wěn)定,一直在上升,說明出現(xiàn)了內(nèi)存泄漏。
在Performance面板記錄下的數(shù)據(jù)中,如果我們打勾Memory選項(xiàng),我們就可以看到Memory行。如果線圖不停的上升,就說明出現(xiàn)了內(nèi)存泄漏。
定位內(nèi)存泄漏在開發(fā)者工具的Memory面板中,我們可以選擇Heap Snapshot,記錄一個當(dāng)前頁面具體內(nèi)存使用情況的快照。注意Shallow Size列和Retained Size列。
Shallow Size是對象自身占用內(nèi)存的大小,而Retained Size是指我們移除Object后能獲得多少空間,也就是將對象本身和連同的相關(guān)對象一起刪除后釋放的內(nèi)存大小。比如一個變量指向一個很大的Object,這個變量本身是個reference很?。⊿hallow Size很小),但是移除這個變量以后,我們就可以獲得很大的空間(Retained Size很大)。
我們可以根據(jù)Shallow Size給Heap Snapshot排序,找到占用內(nèi)存最多的對象,如果不確認(rèn)是否是內(nèi)存泄漏,可以再記錄一個Heap Snapshot做對比。如果該對象的Shallow Size增長了,說明確實(shí)出現(xiàn)了內(nèi)存泄漏。我們可以根據(jù)工具給的提示信息,找到開發(fā)代碼片段做修改。
評估 Audit現(xiàn)在的Audit面板整合了谷歌的Lighthouse服務(wù)。網(wǎng)上還有一些其他不錯的第三方服務(wù)如webpagetest, sonarwhal。
官方文檔
Chrome Developer Tool
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/104525.html
摘要:歡迎來我的個人站點(diǎn)性能優(yōu)化其他優(yōu)化瀏覽器關(guān)鍵渲染路徑開啟性能優(yōu)化之旅高性能滾動及頁面渲染優(yōu)化理論寫法對壓縮率的影響唯快不破應(yīng)用的個優(yōu)化步驟進(jìn)階鵝廠大神用直出實(shí)現(xiàn)網(wǎng)頁瞬開緩存網(wǎng)頁性能管理詳解寫給后端程序員的緩存原理介紹年底補(bǔ)課緩存機(jī)制優(yōu)化動 歡迎來我的個人站點(diǎn) 性能優(yōu)化 其他 優(yōu)化瀏覽器關(guān)鍵渲染路徑 - 開啟性能優(yōu)化之旅 高性能滾動 scroll 及頁面渲染優(yōu)化 理論 | HTML寫法...
摘要:歡迎來我的個人站點(diǎn)性能優(yōu)化其他優(yōu)化瀏覽器關(guān)鍵渲染路徑開啟性能優(yōu)化之旅高性能滾動及頁面渲染優(yōu)化理論寫法對壓縮率的影響唯快不破應(yīng)用的個優(yōu)化步驟進(jìn)階鵝廠大神用直出實(shí)現(xiàn)網(wǎng)頁瞬開緩存網(wǎng)頁性能管理詳解寫給后端程序員的緩存原理介紹年底補(bǔ)課緩存機(jī)制優(yōu)化動 歡迎來我的個人站點(diǎn) 性能優(yōu)化 其他 優(yōu)化瀏覽器關(guān)鍵渲染路徑 - 開啟性能優(yōu)化之旅 高性能滾動 scroll 及頁面渲染優(yōu)化 理論 | HTML寫法...
摘要:歡迎來我的個人站點(diǎn)性能優(yōu)化其他優(yōu)化瀏覽器關(guān)鍵渲染路徑開啟性能優(yōu)化之旅高性能滾動及頁面渲染優(yōu)化理論寫法對壓縮率的影響唯快不破應(yīng)用的個優(yōu)化步驟進(jìn)階鵝廠大神用直出實(shí)現(xiàn)網(wǎng)頁瞬開緩存網(wǎng)頁性能管理詳解寫給后端程序員的緩存原理介紹年底補(bǔ)課緩存機(jī)制優(yōu)化動 歡迎來我的個人站點(diǎn) 性能優(yōu)化 其他 優(yōu)化瀏覽器關(guān)鍵渲染路徑 - 開啟性能優(yōu)化之旅 高性能滾動 scroll 及頁面渲染優(yōu)化 理論 | HTML寫法...
摘要:例如特定的硬件平臺只允許在特定地址獲取特定類型的數(shù)據(jù),否則會導(dǎo)致異常情況性能原因若訪問未對齊的內(nèi)存,將會導(dǎo)致進(jìn)行兩次內(nèi)存訪問,并且要花費(fèi)額外的時(shí)鐘周期來處理對齊及運(yùn)算。因?yàn)樗膬?nèi)存訪問邊界是不對齊的。 showImg(https://segmentfault.com/img/remote/1460000017527314?w=633&h=406); 原文地址:在 Go 中恰到好處的內(nèi)存...
閱讀 2326·2021-09-22 15:27
閱讀 3178·2021-09-03 10:32
閱讀 3506·2021-09-01 11:38
閱讀 2503·2019-08-30 15:56
閱讀 2220·2019-08-30 13:01
閱讀 1543·2019-08-29 12:13
閱讀 1425·2019-08-26 13:33
閱讀 899·2019-08-26 13:30