JavaScript性能優化小知識總結

2021-12-25 全棧開發者中心

  前言

  一直在學習javascript,也有看過《犀利開發Jquery內核詳解與實踐》,對這本書的評價只有兩個字犀利,可能是對javascript理解的還不夠透徹異或是自己太笨,更多的是自己不擅於思考懶得思考以至於裡面說的一些精髓都沒有太深入的理解。

  鑑於想讓自己有一個提升,進不了一個更加廣闊的天地,總得找一個屬於自己的居所好好生存,所以平時會有意無意的去積累一些使用jQuerry的常用知識,特別是對於性能要求這一塊,總是會想是不是有更好的方式來實現。

  下面是我總結的一些小技巧,僅供參考。(我先會說一個總標題,然後用一小段話來說明這個意思 再最後用一個demo來簡單言明)

  避免全局查找

  在一個函數中會用到全局對象存儲為局部變量來減少全局查找,因為訪問局部變量的速度要比訪問全局變量的速度更快些

function search() { //當我要使用當前頁面地址和主機域名 alert(window.location.href + window.location.host);}//最好的方式是如下這樣 先用一個簡單變量保存起來function search() { var location = window.location; alert(location.href + location.host);}

  定時器

  如果針對的是不斷運行的代碼,不應該使用setTimeout,而應該是用setInterval,因為setTimeout每一次都會初始化一個定時器,而setInterval只會在開始的時候初始化一個定時器

var timeoutTimes = 0;function timeout() { timeoutTimes++; if (timeoutTimes < 10) { setTimeout(timeout, 10); }}timeout();//可以替換為:var intervalTimes = 0;function interval() { intervalTimes++; if (intervalTimes >= 10) { clearInterval(interv); }}var interv = setInterval(interval, 10);

  字符串連接

  如果要連接多個字符串,應該少使用+=,如

  s+=a;

  s+=b;

  s+=c;

  應該寫成s+=a + b + c;

  而如果是收集字符串,比如多次對同一個字符串進行+=操作的話,最好使用一個緩存,使用JavaScript數組來收集,最後使用join方法連接起來

var buf = [];for (var i = 0; i < 100; i++) { buf.push(i.toString());}var all = buf.join("");

  避免with語句

  和函數類似 ,with語句會創建自己的作用域,因此會增加其中執行的代碼的作用域鏈的長度,由於額外的作用域鏈的查找,在with語句中執行的代碼肯定會比外面執行的代碼要慢,在能不使用with語句的時候儘量不要使用with語句。

with (a.b.c.d) { property1 = 1; property2 = 2; } //可以替換為: var obj = a.b.c.d; obj.property1 = 1; obj.property2 = 2;

  數字轉換成字符串

  般最好用"" + 1來將數字轉換成字符串,雖然看起來比較醜一點,但事實上這個效率是最高的,性能上來說:

  ("" +) > String() > .toString() > new String()

  浮點數轉換成整型

  很多人喜歡使用parseInt(),其實parseInt()是用於將字符串轉換成數字,而不是浮點數和整型之間的轉換,我們應該使用Math.floor()或者Math.round()

  各種類型轉換

var myVar = "3.14159", str = "" + myVar, // to string i_int = ~ ~myVar, // to integer f_float = 1 * myVar, // to float b_bool = !!myVar, /* to boolean - any string with length and any number except 0 are true */ array = [myVar]; // to array

  如果定義了toString()方法來進行類型轉換的話,推薦顯式調用toString(),因為內部的操作在嘗試所有可能性之後,會嘗試對象的toString()方法嘗試能否轉化為String,所以直接調用這個方法效率會更高

  多個類型聲明

  在JavaScript中所有變量都可以使用單個var語句來聲明,這樣就是組合在一起的語句,以減少整個腳本的執行時間,就如上面代碼一樣,上面代碼格式也挺規範,讓人一看就明了。

  插入迭代器

  如var name=values[i]; i++;前面兩條語句可以寫成var name=values[i++]

  使用直接量

var aTest = new Array(); //替換為var aTest = [];var aTest = new Object; //替換為var aTest = {};var reg = new RegExp(); //替換為var reg = /../;//如果要創建具有一些特性的一般對象,也可以使用字面量,如下:var oFruit = new O;oFruit.color = "red";oFruit.name = "apple";//前面的代碼可用對象字面量來改寫成這樣:var oFruit = { color: "red", name: "apple" };

  使用DocumentFragment優化多次append

  一旦需要更新DOM,請考慮使用文檔碎片來構建DOM結構,然後再將其添加到現存的文檔中。

for (var i = 0; i < 1000; i++) { var el = document.createElement('p'); el.innerHTML = i; document.body.appendChild(el);}//可以替換為:var frag = document.createDocumentFragment();for (var i = 0; i < 1000; i++) { var el = document.createElement('p'); el.innerHTML = i; frag.appendChild(el);}document.body.appendChild(frag);

  使用一次innerHTML賦值代替構建dom元素

  對於大的DOM更改,使用innerHTML要比使用標準的DOM方法創建同樣的DOM結構快得多。

var frag = document.createDocumentFragment();for (var i = 0; i < 1000; i++) { var el = document.createElement('p'); el.innerHTML = i; frag.appendChild(el);}document.body.appendChild(frag);//可以替換為:var html = [];for (var i = 0; i < 1000; i++) { html.push('<p>' + i + '</p>');}document.body.innerHTML = html.join('');

  通過模板元素clone,替代createElement

  很多人喜歡在JavaScript中使用document.write來給頁面生成內容。事實上這樣的效率較低,如果需要直接插入HTML,可以找一個容器元素,比如指定一個div或者span,並設置他們的innerHTML來將自己的HTML代碼插入到頁面中。通常我們可能會使用字符串直接寫HTML來創建節點,其實這樣做,1無法保證代碼的有效性2字符串操作效率低,所以應該是用document.createElement()方法,而如果文檔中存在現成的樣板節點,應該是用cloneNode()方法,因為使用createElement()方法之後,你需要設置多次元素的屬性,使用cloneNode()則可以減少屬性的設置次數——同樣如果需要創建很多元素,應該先準備一個樣板節點

var frag = document.createDocumentFragment();for (var i = 0; i < 1000; i++) { var el = document.createElement('p'); el.innerHTML = i; frag.appendChild(el);}document.body.appendChild(frag);//替換為:var frag = document.createDocumentFragment();var pEl = document.getElementsByTagName('p')[0];for (var i = 0; i < 1000; i++) { var el = pEl.cloneNode(false); el.innerHTML = i; frag.appendChild(el);}document.body.appendChild(frag);

  使用firstChild和nextSibling代替childNodes遍歷dom元素

var nodes = element.childNodes;for (var i = 0, l = nodes.length; i < l; i++) { var node = nodes[i]; //……}//可以替換為:var node = element.firstChild;while (node) { //…… node = node.nextSibling;

  刪除DOM節點

  刪除dom節點之前,一定要刪除註冊在該節點上的事件,不管是用observe方式還是用attachEvent方式註冊的事件,否則將會產生無法回收的內存。另外,在removeChild和innerHTML=』』二者之間,儘量選擇後者。因為在sIEve(內存洩露監測工具)中監測的結果是用removeChild無法有效地釋放dom節點

  使用事件代理

  任何可以冒泡的事件都不僅僅可以在事件目標上進行處理,目標的任何祖先節點上也能處理,使用這個知識就可以將事件處理程序附加到更高的地方負責多個目標的事件處理,同樣,對於內容動態增加並且子節點都需要相同的事件處理函數的情況,可以把事件註冊提到父節點上,這樣就不需要為每個子節點註冊事件監聽了。另外,現有的js庫都採用observe方式來創建事件監聽,其實現上隔離了dom對象和事件處理函數之間的循環引用,所以應該儘量採用這種方式來創建事件監聽

  重複使用的調用結果,事先保存到局部變量

//避免多次取值的調用開銷 var h1 = element1.clientHeight + num1; var h2 = element1.clientHeight + num2; //可以替換為: var eleHeight = element1.clientHeight; var h1 = eleHeight + num1; var h2 = eleHeight + num2;

  注意NodeList

  最小化訪問NodeList的次數可以極大的改進腳本的性能

var images = document.getElementsByTagName('img');for (var i = 0, len = images.length; i < len; i++) {}

  編寫JavaScript的時候一定要知道何時返回NodeList對象,這樣可以最小化對它們的訪問

  要了解了當使用NodeList對象時,合理使用會極大的提升代碼執行速度

  優化循環

  可以使用下面幾種方式來優化循環

  大多數循環使用一個從0開始、增加到某個特定值的迭代器,在很多情況下,從最大值開始,在循環中不斷減值的迭代器更加高效

  由於每次循環過程都會計算終止條件,所以必須保證它儘可能快,也就是說避免屬性查找或者其它的操作,最好是將循環控制量保存到局部變量中,也就是說對數組或列表對象的遍歷時,提前將length保存到局部變量中,避免在循環的每一步重複取值。

var list = document.getElementsByTagName('p');for (var i = 0; i < list.length; i++) { //……}//替換為:var list = document.getElementsByTagName('p');for (var i = 0, l = list.length; i < l; i++) { //……}

  循環體是執行最多的,所以要確保其被最大限度的優化

  在JavaScript中,我們可以使用for(;;),while(),for(in)三種循環,事實上,這三種循環中for(in)的效率極差,因為他需要查詢散列鍵,只要可以,就應該儘量少用。for(;;)和while循環,while循環的效率要優於for(;;),可能是因為for(;;)結構的問題,需要經常跳轉回去。

var arr = [1, 2, 3, 4, 5, 6, 7];var sum = 0;for (var i = 0, l = arr.length; i < l; i++) { sum += arr[i];}//可以考慮替換為:var arr = [1, 2, 3, 4, 5, 6, 7];var sum = 0, l = arr.length;while (l--) { sum += arr[l];}

  最常用的for循環和while循環都是前測試循環,而如do-while這種後測試循環,可以避免最初終止條件的計算,因此運行更快。

  展開循環

  當循環次數是確定的,消除循環並使用多次函數調用往往會更快。

  避免雙重解釋

  如果要提高代碼性能,儘可能避免出現需要按照JavaScript解釋的字符串,也就是

  使用eval相當於在運行時再次調用解釋引擎對內容進行運行,需要消耗大量時間,而且使用Eval帶來的安全性問題也是不容忽視的。

  不要給setTimeout或者setInterval傳遞字符串參數

var num = 0;setTimeout('num++', 10);//可以替換為:var num = 0;function addNum() { num++;}setTimeout(addNum, 10);

  縮短否定檢測

if (oTest != '#ff0000') { //do something}if (oTest != null) { //do something}if (oTest != false) { //do something}//雖然這些都正確,但用邏輯非操作符來操作也有同樣的效果:if (!oTest) { //do something}

  條件分支

if (a > b) { num = a;} else { num = b;}//可以替換為:num = a > b ? a : b;

  使用常量

重複值:任何在多處用到的值都應該抽取為一個常量

用戶界面字符串:任何用於顯示給用戶的字符串,都應該抽取出來以方便國際化

URLs:在Web應用中,資源位置很容易變更,所以推薦用一個公共地方存放所有的URL

任意可能會更改的值:每當你用到字面量值的時候,你都要問一下自己這個值在未來是不是會變化,如果答案是「是」,那麼這個值就應該被提取出來作為一個常量。

  避免與null進行比較

  由於JavaScript是弱類型的,所以它不會做任何的自動類型檢查,所以如果看到與null進行比較的代碼,嘗試使用以下技術替換

如果值應為一個引用類型,使用instanceof操作符檢查其構造函數

如果值應為一個基本類型,作用typeof檢查其類型

如果是希望對象包含某個特定的方法名,則使用typeof操作符確保指定名字的方法存在於對象上

  避免全局量

  全局變量應該全部字母大寫,各單詞之間用_下劃線來連接。儘可能避免全局變量和函數, 儘量減少全局變量的使用,因為在一個頁面中包含的所有JavaScript都在同一個域中運行。所以如果你的代碼中聲明了全局變量或者全局函數的話,後面的代碼中載入的腳本文件中的同名變量和函數會覆蓋掉(overwrite)你的。

//糟糕的全局變量和全局函數var current = null;function init(){//...}function change() { //...}function verify() { //...}//解決辦法有很多,Christian Heilmann建議的方法是://如果變量和函數不需要在「外面」引用,那麼就可以使用一個沒有名字的方法將他們全都包起來。(function(){var current = null;function init() { //...}function change() { //...}function verify() { //...}})();//如果變量和函數需要在「外面」引用,需要把你的變量和函數放在一個「命名空間」中//我們這裡用一個function做命名空間而不是一個var,因為在前者中聲明function更簡單,而且能保護隱私數據myNameSpace = function() { var current = null; function init() { //... } function change() { //... } function verify() { //... }//所有需要在命名空間外調用的函數和屬性都要寫在return裡面 return { init: init, //甚至你可以為函數和屬性命名一個別名 set: change };};

  尊重對象的所有權

  因為JavaScript可以在任何時候修改任意對象,這樣就可以以不可預計的方式覆寫默認的行為,所以如果你不負責維護某個對象,它的對象或者它的方法,那麼你就不要對它進行修改,具體一點就是說:

不要為實例或原型添加屬性

不要為實例或者原型添加方法

不要重定義已經存在的方法

不要重複定義其它團隊成員已經實現的方法,永遠不要修改不是由你所有的對象,你可以通過以下方式為對象創建新的功能:

創建包含所需功能的新對象,並用它與相關對象進行交互

創建自定義類型,繼承需要進行修改的類型,然後可以為自定義類型添加額外功能

  循環引用

  如果循環引用中包含DOM對象或者ActiveX對象,那麼就會發生內存洩露。內存洩露的後果是在瀏覽器關閉前,即使是刷新頁面,這部分內存不會被瀏覽器釋放。

  簡單的循環引用:

var el = document.getElementById('MyElement');var func = function () { //…}el.func = func;func.element = el;

  但是通常不會出現這種情況。通常循環引用發生在為dom元素添加閉包作為expendo的時候。

function init() { var el = document.getElementById('MyElement'); el.onclick = function () { //…… } } init();

  init在執行的時候,當前上下文我們叫做context。這個時候,context引用了el,el引用了function,function引用了context。這時候形成了一個循環引用。

  下面2種方法可以解決循環引用:

  1) 置空dom對象

function init() { var el = document.getElementById('MyElement'); el.onclick = function () { //…… }}init();//可以替換為:function init() { var el = document.getElementById('MyElement'); el.onclick = function () { //…… } el = null;}init();

  將el置空,context中不包含對dom對象的引用,從而打斷循環應用。

  如果我們需要將dom對象返回,可以用如下方法:

function init() { var el = document.getElementById('MyElement'); el.onclick = function () { //…… } return el;}init();//可以替換為:function init() { var el = document.getElementById('MyElement'); el.onclick = function () { //…… } try { return el; } finally { el = null; }}init();

  2) 構造新的context

function init() { var el = document.getElementById('MyElement'); el.onclick = function () { //…… }}init();//可以替換為:function elClickHandler() { //……}function init() { var el = document.getElementById('MyElement'); el.onclick = elClickHandler;}init();

  把function抽到新的context中,這樣,function的context就不包含對el的引用,從而打斷循環引用。

  通過javascript創建的dom對象,必須append到頁面中

  IE下,腳本創建的dom對象,如果沒有append到頁面中,刷新頁面,這部分內存是不會回收的!

function create() { var gc = document.getElementById('GC'); for (var i = 0; i < 5000; i++) { var el = document.createElement('div'); el.innerHTML = "test"; //下面這句可以注釋掉,看看瀏覽器在任務管理器中,點擊按鈕然後刷新後的內存變化 gc.appendChild(el); }}

  釋放dom元素佔用的內存

  將dom元素的innerHTML設置為空字符串,可以釋放其子元素佔用的內存。

  在rich應用中,用戶也許會在一個頁面上停留很長時間,可以使用該方法釋放積累得越來越多的dom元素使用的內存。

  釋放javascript對象

  在rich應用中,隨著實例化對象數量的增加,內存消耗會越來越大。所以應當及時釋放對對象的引用,讓GC能夠回收這些內存控制項。

  對象:obj = null

  對象屬性:delete obj.myproperty

  數組item:使用數組的splice方法釋放數組中不用的item

  避免string的隱式裝箱

  對string的方法調用,比如'xxx'.length,瀏覽器會進行一個隱式的裝箱操作,將字符串先轉換成一個String對象。推薦對聲明有可能使用String實例方法的字符串時,採用如下寫法:

  var myString = new String('Hello World');

  鬆散耦合

  1、解耦HTML/JavaScript

  JavaScript和HTML的緊密耦合:直接寫在HTML中的JavaScript、使用包含內聯代碼的<script>元素、使用HTML屬性來分配事件處理程序等

  HTML和JavaScript的緊密耦合:JavaScript中包含HTML,然後使用innerHTML來插入一段html文本到頁面

  其實應該是保持層次的分離,這樣可以很容易的確定錯誤的來源,所以我們應確保HTML呈現應該儘可能與JavaScript保持分離

  2、解耦CSS/JavaScript

  顯示問題的唯一來源應該是CSS,行為問題的唯一來源應該是JavaScript,層次之間保持鬆散耦合才可以讓你的應用程式更加易於維護,所以像以下的代碼element.style.color=」red」儘量改為element.className=」edit」,而且不要在css中通過表達式嵌入JavaScript

  3、解耦應用程式/事件處理程序

  將應用邏輯和事件處理程序相分離:一個事件處理程序應該從事件對象中提取,並將這些信息傳送給處理應用邏輯的某個方法中。這樣做的好處首先可以讓你更容易更改觸發特定過程的事件,其次可以在不附加事件的情況下測試代碼,使其更易創建單元測試

  性能方面的注意事項

  1、儘量使用原生方法

  2、switch語句相對if較快

  通過將case語句按照最可能到最不可能的順序進行組織

  3、位運算較快

  當進行數字運算時,位運算操作要比任何布爾運算或者算數運算快

  4、巧用||和&&布爾運算符

function eventHandler(e) { if (!e) e = window.event;}//可以替換為:function eventHandler(e) { e = e || window.event;}

if (myobj) { doSomething(myobj);}//可以替換為:myobj && doSomething(myobj);

  避免錯誤應注意的地方

  1、每條語句末尾須加分號

  在if語句中,即使條件表達式只有一條語句也要用{}把它括起來,以免後續如果添加了語句之後造成邏輯錯誤

  2、使用+號時需謹慎

  JavaScript 和其他程式語言不同的是,在 JavaScript 中,'+'除了表示數字值相加,字符串相連接以外,還可以作一元運算符用,把字符串轉換為數字。因而如果使用不當,則可能與自增符'++'混淆而引起計算錯誤

var valueA = 20; var valueB = "10"; alert(valueA + valueB); //ouput: 2010 alert(valueA + (+valueB)); //output: 30 alert(valueA + +valueB); //output:30 alert(valueA ++ valueB); //Compile error

  3、使用return語句需要注意

  一條有返回值的return語句不要用()括號來括住返回值,如果返回表達式,則表達式應與return關鍵字在同一行,以避免壓縮時,壓縮工具自動加分號而造成返回與開發人員不一致的結果

function F1() { var valueA = 1; var valueB = 2; return valueA + valueB; }function F2() { var valueA = 1; var valueB = 2; return valueA + valueB;}alert(F1()); //output: 3 alert(F2()); //ouput: undefined

  ==和===的區別

  避免在if和while語句的條件部分進行賦值,如if (a = b),應該寫成if (a == b),但是在比較是否相等的情況下,最好使用全等運行符,也就是使用===和!==操作符會相對於==和!=會好點。==和!=操作符會進行類型強制轉換

var valueA = "1";var valueB = 1;if (valueA == valueB) { alert("Equal");}else { alert("Not equal");}//output: "Equal"if (valueA === valueB) { alert("Equal");}else { alert("Not equal");}//output: "Not equal"

  不要使用生偏語法

  不要使用生偏語法,寫讓人迷惑的代碼,雖然計算機能夠正確識別並運行,但是晦澀難懂的代碼不方便以後維護

  函數返回統一類型

  雖然JavaScript是弱類型的,對於函數來說,前面返回整數型數據,後面返回布爾值在編譯和運行都可以正常通過,但為了規範和以後維護時容易理解,應保證函數應返回統一的數據類型

  總是檢查數據類型

  要檢查你的方法輸入的所有數據,一方面是為了安全性,另一方面也是為了可用性。用戶隨時隨地都會輸入錯誤的數據。這不是因為他們蠢,而是因為他們很忙,並且思考的方式跟你不同。用typeof方法來檢測你的function接受的輸入是否合法

  何時用單引號,何時用雙引號

  雖然在JavaScript當中,雙引號和單引號都可以表示字符串,為了避免混亂,我們建議在HTML中使用雙引號,在JavaScript中使用單引號,但為了兼容各個瀏覽器,也為了解析時不會出錯,定義JSON對象時,最好使用雙引號

  部署

用JSLint運行JavaScript驗證器來確保沒有語法錯誤或者是代碼沒有潛在的問

部署之前推薦使用壓縮工具將JS文件壓縮

文件編碼統一用UTF-8

JavaScript 程序應該儘量放在 .js 的文件中,需要調用的時候在 HTML 中以 <script src="filename.js"> 的形式包含進來。JavaScript 代碼若不是該 HTML 文件所專用的,則應儘量避免在 HTML 文件中直接編寫 JavaScript 代碼。因為這樣會大大增加 HTML 文件的大小,無益於代碼的壓縮和緩存的使用。另外,<script src="filename.js"> 標籤應儘量放在文件的後面,最好是放在</body>標籤前。這樣會降低因加載 JavaScript 代碼而影響頁面中其它組件的加載時間。

  永遠不要忽略代碼優化工作,重構是一項從項目開始到結束需要持續的工作,只有不斷的優化代碼才能讓代碼的執行效率越來越好

  via:YouYaInsist

相關焦點

  • JavaScript 性能優化的小知識總結
    ,也有看過《犀利開發 Jquery 內核詳解與實踐》,對這本書的評價只有兩個字犀利,可能是對 javascript 理解的還不夠透徹異或是自己太笨,更多的是自己不擅於思考懶得思考以至於裡面說的一些精髓都沒有太深入的理解。
  • 網頁性能之html css javascript
    前言html css javascript可以算是前端必須掌握的東西了,但是我們的瀏覽器是怎樣解析這些東西的呢 我們如何處理html css javascript這些東西來讓我們的網頁更加合理,在我這裡做了一些實驗,總結起來給大家看看。
  • Javascript 性能測試 [每日前端夜話0xB1]
    正文共:916 字預計閱讀時間:7 分鐘作者:Deepak Gupta翻譯:瘋狂的技術宅來源:codeburst我們都知道 for 循環比 each 或 javascript 函數更快,因為在javascript函數的引擎下可能會使用for循環或其他我不確定的東西。
  • Android性能優化總結
    這是來自一位粉絲「MeloDev」的投稿,講真,我這裡投稿的不少,但是只有我自己覺得很不錯的才會通過,這篇文章我覺得對大家有用,而且性能優化也算是我面試必問的一個話題了,所以這裡推薦給大家。耗電量:耗電量大會導致機器發熱、縮短機器的有效使用時長;3. 內存:內存消耗大會導致頻繁GC,GC時會暫停其它工作,導致頁面卡頓;內存洩露會導致剩餘可用內存越來越小;內存不足會導致應用異常;4. 網絡:頻繁的網絡訪問會導致耗電和影響應用的性能;網絡交互數據大小會影響網絡傳輸的效率;5.
  • 不容忽視:MongoDB的JavaScript性能
    【IT168 技術】mongodb使用javascript做shell, mongodb的db.eval可以提供給數據驅動與這種javascript shell類似的js接口。
  • JavaScript核心知識總結(下)
    性能優化的方向主要分為以下幾點:•編寫高性能的 JavaScript•瀏覽器渲染•網絡優化•打包工具的優化,以 webpack 為例編寫高性能的JavaScript常見編碼規範•將 js 腳本放在頁面底部,加快渲染頁面•將 js 腳本將腳本成組打包,減少請求•使用非阻塞方式下載 js 腳本•儘量使用局部變量來保存全局變量•遵循嚴格模式:"use strict";•儘量減少使用閉包•減少對象成員嵌套
  • Android性能優化:手把手帶你全面實現內存優化
    最近有想換工作的同學們,可參考《5月技術崗位內推|RN開發招聘啦》,再往下看,一篇關於性能優化的好文章,很值得去學習。前言在 Android開發中,性能優化策略十分重要本文主要講解性能優化中的內存優化,希望你們會喜歡目錄
  • Android性能優化:帶你全面實現內存優化
    本文主要講解性能優化中的內存優化,希望你們會喜歡目錄1.儲備知識:Android 內存管理機制3.1 簡介),從而通知虛擬機 應用程式需更大的堆內存,但不建議 & 不鼓勵該做法4.6 額外小技巧此處,還有一些內存優化的小技巧希望告訴給大家技巧1:獲取當前可使用的內存大小調用 ActivityManager.getMemoryClass()方法可獲取當前應用可用的內存大小(單位 = 兆)技巧2
  • JavaScript 數組操作函數總結
    js中數組操作函數還是非常多的,今天忽然想到來總結一下,也算是溫故而知新吧。
  • JavaScript性能優化之分時函數(timeChunk)函數的實現
    「同樣也是為了讓JS的性能更加的出色,避免在短時間調用大量數據的時候產生的卡頓感!說白了一起都是為了用戶體驗!畢竟體驗為王嘛!」,麥克回答道姜小白又問:「舉個真實案例OK嗎?」「這個在網上有很多,比如手機版的今日頭條,我們在刷新聞或者視頻的時候,只要產生滾動就會加載數據沒錯吧?」
  • etcd 的性能怎麼樣?需要優化嗎?
    從其他方面來看,etcd 所在宿主機的內核參數和 grpc api 層的延遲,也將影響 etcd 的性能。原來的實現方式是遍歷內部引 BTree 使用的內部鎖粒度比較粗,這個鎖很大程度上影響了 etcd 的性能,新的優化減少了這一部分的影響,降低了延遲;針對於lease 規模使用的優化:優化了 lease revoke 和過期失效的算法,將原來遍歷失效 list 時間複雜度從 O(n) 降為 O(logn),解決了 lease 規模化使用的問題;最後是針對於
  • 新手必須要懂的PHP學習路線以及10個PHP優化技巧
    (1個月)深入學習zf框架(增刪改查,權限控制,前端模板頁面等)(長期總結)對自己做過的小項目進行總結,用面向對象思想,對結構優化。先從留言本做起,再做個個人博客,然後再做個複雜點兒的CMS,或者小OA,所謂經驗,其實就是解決問題的方法,從項目中不斷思考,就能不斷收穫!想學好PHP OOP, 直接上Zend Framework 2,半年後你會覺得自己進步許多總結:自學非常重要,實際項目經驗也很重要。不要以為計算機基礎不重要,學習計算機基礎對學習程式語言非常有用。
  • 說說那些經典的web前端面試題-開發及性能優化
    1、規避javascript多人開發函數重名問題命名空間封閉空間js模塊化mvc(數據層、表現層、控制層)seajs4、web前端開發,如何提高頁面性能優化?不要在 HTML 中使用縮放圖片使用恰當的圖片格式使用 CSS Sprites 技巧對圖片優化5、前端開發中,如何優化圖像?
  • javascript入門推薦書籍-授人以魚不如授人以漁
    我們應該把 javascript 當作一門真正的程式語言,而不是玩具語言。3、javascript高級程序設計這本書已經出了第二版,而且與第一版相比內 容更新很大,直接第二版就行。不要被書名的「高級」唬住,只要有JS基礎語法知識和DOM基礎知識就行,而且本書開始階段還是介紹JS和DOM的語法知 識。
  • Android性能優化--內存優化
    本文來自Dotry投稿,連結:https://www.jianshu.com/p/38b627adaecd上一篇文章關於Android性能優化--啟動優化探討了啟動優化相關的知識點,在本篇將介紹內存優化的相關優化。
  • JavaScript能應用在哪些方向?未來前景怎麼樣?
    下面和千鋒廣州小編一起來看看吧!網頁開發css,javascript,html。而天生異步的處理,讓他在IO方面的性能似乎看起來一點不弱。客戶端開發「不能開發客戶端桌面的語言不是好語言。」通過electron技術,Javascript開發在客戶端開發上也大放異彩,許許多多多編輯器都是採用的js開發的,例如我們耳熟能詳的atom,以及好用到哭的vscode,它們都是使用js開發出來的客戶端軟體,或許性能表現方面不如Java那般強勢,但是隨著個人電腦的性能的提升,哪點效率問題幾乎可以被我們忽視掉。
  • javascript經典算法之最小硬幣找零問題實戰
    本文轉載自【微信公眾號:趣談前端,ID:beautifulFront】經微信公眾號授權轉載,如需轉載與原文作者聯繫前言筆者之前也斷斷續續寫過幾篇javascript數據結構和算法的文章,之所以要寫,是因為它們很重要。
  • 前端性能優化之利用 Chrome Dev Tools 性能分析
    頁面圖片優化,部署在不同的CDN域名下,用webp/dpg等格式圖片,圖片切割等http 協議有部分採用 http2,多路復用,加快資源加載按需加載,菜單先加載第一屏的圖標,滑動到第二屏時再加載第二屏的圖標而個人認為,還可以考慮用上的一些性能優化手段有:html 的大小為138kb,Content Download
  • Nginx在高並發下的性能優化點!有這篇就夠了!
    例如:Nginx 的進程模型本篇,我們則來講講Nginx的幾種性能優化方式。fastcgi_buffers指令中的每塊大小,可以將這個值設置更小。/json application/javascript application/x-javascriptapplication/xml;gzip_vary on;gzip_proxied any;gzip on; #開啟壓縮功能gzip_min_length
  • 最強大、最牛逼的javascript視頻
    是一門非常強大的腳本語言,應用的範圍非常廣泛,每一個web開發者學好javascript也是必須的,本套視頻教程詳細的講解了javascript各個知識點、關鍵點,其中涉及到高深的函數概念、原型概念、接口概念、單體概念、更是詳細的講解了javascript設計模式。 本視