摘要:編寫高性能的翻譯自的文章。編譯器自然地希望能夠處理那些單態(tài)可預(yù)測的數(shù)據(jù)結(jié)構(gòu)參數(shù)統(tǒng)計(jì)等。使用嚴(yán)格比較操作符能夠避免編譯器進(jìn)行類型推導(dǎo)與轉(zhuǎn)換,從而提高一定的性能。另外,與語句在循環(huán)中的性能也是不錯的,這一點(diǎn)使用的時(shí)候不用擔(dān)心。
2016:編寫高性能的JavaScript翻譯自Felix Maier的文章Writing-Efficient-JavaScript。本文從屬于筆者的Web 前端入門與最佳實(shí)踐中JavaScript 入門與最佳實(shí)踐系列文章。
本文的初衷是想介紹如何利用些簡單的代碼小技巧就能促進(jìn)JavaScript編譯器的優(yōu)化進(jìn)程從而提升代碼運(yùn)行效率。特別是在游戲這種對于垃圾回收速度要求較高,你性能稍微差點(diǎn)用戶就能見到白屏的地方。
Monomorphism:單態(tài)性JavaScript中允許函數(shù)調(diào)用時(shí)候傳入動態(tài)參數(shù),不過就以簡單的2參數(shù)函數(shù)為例,當(dāng)你的參數(shù)類型、參數(shù)數(shù)目與返回類型動態(tài)調(diào)用時(shí)才能決定,編譯器需要更多的時(shí)間來解析。編譯器自然地希望能夠處理那些單態(tài)可預(yù)測的數(shù)據(jù)結(jié)構(gòu)、參數(shù)統(tǒng)計(jì)等。
function example(a, b) { // we expect a, b to be numeric console.log(++a * ++b); }; example(); // bad example(1); // still bad example("1", 2); // dammit meg example(1, 2); // goodConstants:常量
使用常量能夠讓編譯器在編譯時(shí)即完成變量的值替換:
const a = 42; // we can easily unfold this const b = 1337 * 2; // we can resolve this expression const c = a + b; // still can be resolved const d = Math.random() * c; // we can only unfold "c" // before unfolding a; b; c; d; // after unfolding // we can do this at compile time! 42; 2674; 2716; Math.random() * 2716;Inlining:內(nèi)聯(lián)
JIT編譯器能夠找出你的代碼中被執(zhí)行次數(shù)最多的部分,將你的代碼分割成多個(gè)小的代碼塊能夠有助于編譯器在編譯時(shí)將這些代碼塊轉(zhuǎn)化為內(nèi)聯(lián)格式然后增加執(zhí)行速度。
Data Types:數(shù)據(jù)類型盡可能地多用Numbers與Booleans類型,因?yàn)樗麄兣c其他類似于字符串等原始類型相比性能表現(xiàn)更好。使用字符串類型可能會帶來額外的垃圾回收消耗。
const ROBOT = 0; const HUMAN = 1; const SPIDER = 2; let E_TYPE = { Robot: ROBOT, Human: HUMAN, Spider: SPIDER }; // bad // avoid uncached strings in heavy tasks (or better in general) if (entity.type === "Robot") { } // good // the compiler can resolve member expressions // without much deepness pretty fast if (entity.type === E_TYPE.Robot) { } // perfect // right side of binary expression can even get unfold if (entity.type === ROBOT) { }Strict & Abstract Operators
盡可能使用===這個(gè)嚴(yán)格比較操作符而不是==操作符。使用嚴(yán)格比較操作符能夠避免編譯器進(jìn)行類型推導(dǎo)與轉(zhuǎn)換,從而提高一定的性能。
Strict ConditionsJavaScript中的if語句也非常靈活,你可以直接在if(a) then bla這個(gè)類型的條件選擇語句中傳入隨意類似的a值。不過這種情況下,就像上文提及的嚴(yán)格比較操作符與寬松比較操作符一樣,編譯器需要將其轉(zhuǎn)化為多個(gè)數(shù)據(jù)類型進(jìn)行比較,而不能立刻得出結(jié)果。當(dāng)然,這并不是一味的反對使用簡寫方式,而是在非常強(qiáng)調(diào)性能的場景,還是建議做好每一個(gè)細(xì)節(jié)的優(yōu)化:
let a = 2; // bad // abstracts to check in the worst case: // - is value equal to true // - is value greater than zero // - is value not null // - is value not NaN // .. if (a) { // if a is true, do something } // good if (a === 2) { // do sth } // same goes for functions function b() { return (!false); }; if (b()) { // get in here slow } if (b() === true) { // get in here fast // the compiler knows a specific value to compare with }Arguments
盡可能避免使用arguments[index]方式進(jìn)行參數(shù)獲取,并且盡量避免修改傳入的參數(shù)變量:
function mul(a, b) { return (arguments[0]*arguments[1]); // bad, very slow return (a*b); // good }; function test(a, b) { a = 5; // bad, dont modify argument identifiers let tmp = a; // good tmp *= 2; // we can now modify our fake "a" };Toxicity:這些關(guān)鍵字有毒 Toxicity
如下列舉的幾個(gè)語法特性會影響優(yōu)化進(jìn)程:
eval
with
try/catch
同時(shí)盡量避免在函數(shù)內(nèi)聲明函數(shù)或者閉包,可能在大量的運(yùn)算中導(dǎo)致過多的垃圾回收操作。
ObjecsObject實(shí)例通常會共享隱類,因此當(dāng)我們訪問或者設(shè)置某個(gè)實(shí)例的未預(yù)定義變量值的時(shí)候會創(chuàng)建一個(gè)隱類。
// our hidden class "hc_0" class Vector { constructor(x, y) { // compiler finds and expects member declarations here this.x = x; this.y = y; } }; // both vector objects share hidden class "hc_0" let vec1 = new Vector(0, 0); let vec2 = new Vector(2, 2); // bad, vec2 got hidden class "hc_1" now vec2.z = 0; // good, compiler knows this member vec2.x = 1;Loops
盡可能的緩存數(shù)組長度的計(jì)算值,并且盡可能在同一個(gè)數(shù)組中存放單個(gè)類型。避免使用for-in語法來遍歷某個(gè)數(shù)組,因?yàn)樗娴暮苈A硗猓琧ontinue與break語句在循環(huán)中的性能也是不錯的,這一點(diǎn)使用的時(shí)候不用擔(dān)心。另外,盡可能將短小的邏輯部分拆分到獨(dú)立的函數(shù)中,這樣更有利于編譯器進(jìn)行優(yōu)化。另外,使用前綴自增表達(dá)式,也能帶來小小的性能提升。(++i代替i++)
let badarray = [1, true, 0]; // bad, dont mix types let array = [1, 0, 1]; // happy compiler // bad choice for (let key in array) { }; // better // but always try to cache the array size let i = 0; for (; i < array.length; ++i) { key = array[i]; }; // good let i = 0; let key = null; let length = array.length; for (; i < length; ++i) { key = array[i]; };drawImage
draeImage函數(shù)算是最快的2D Canvas API之一了,不過我們需要注意的是如果為了圖方便省略了全參數(shù)傳入,也會增加性能損耗:
// bad ctx.drawImage( img, x, y ); // good ctx.drawImage( img, // clipping sx, sy, sw, sh, // actual stuff x, y, w, h ); // much hax // no subpixel rendering by passing integers ctx.drawImage( img, sx|0, sy|0, sw|0, sh|0, x|0, y|0, w|0, h|0 );
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/81042.html
摘要:與是年最早公開發(fā)布的兩個(gè)框架,后來者還包括與。此外,另一重心是與團(tuán)隊(duì)的合作,預(yù)計(jì)將貫穿年。年展望對平臺而言,年的重點(diǎn)是提升穩(wěn)定性與采納率。最早由開發(fā),于年公開發(fā)布。時(shí)間會告訴我們,的極速增長能否在年持續(xù)下去。 【編者按】本文作者為資深 Web 開發(fā)者 TJ VanToll, TJ 專注于移動端 Web 應(yīng)用及其性能,是《jQuery UI 實(shí)踐》 一書的作者。 本文系 OneAPM 工...
摘要:歡迎來我的博客閱讀開發(fā)者所需要知道的一是一款擁有自動垃圾回收功能的編程語言。它隨著的第一版發(fā)布而發(fā)布以及開源。年月,基金宣布和合并,合并版本在未來發(fā)布。年月日,官方公布又一個(gè)新的名為的優(yōu)化編譯器,主要提供的新語法,以及提高性能。 歡迎來我的博客閱讀:「JavaScript 開發(fā)者所需要知道的 V8(一):V8 In NodeJS」 Motivation JavaScript 是一款擁有...
摘要:在年成為最大贏家,贏得了實(shí)現(xiàn)的風(fēng)暴之戰(zhàn)。和他的競爭者位列第二沒有前端開發(fā)者可以忽視和它的生態(tài)系統(tǒng)。他的殺手級特性是探測功能,通過檢查任何用戶的功能,以直觀的方式讓開發(fā)人員檢查所有端點(diǎn)。 2016 JavaScript 后起之秀 本文轉(zhuǎn)載自:眾成翻譯譯者:zxhycxq鏈接:http://www.zcfy.cc/article/2410原文:https://risingstars2016...
摘要:年,軟件開發(fā)界發(fā)生了很多變化。六數(shù)據(jù)存儲是一個(gè)關(guān)系型數(shù)據(jù)庫管理系統(tǒng),由瑞典公司開發(fā),目前屬于旗下公司。最流行的關(guān)系型數(shù)據(jù)庫管理系統(tǒng),在應(yīng)用方面是最好的,關(guān)系數(shù)據(jù)庫管理系統(tǒng)應(yīng)用軟件之一。七是最新的修訂版本,年月由萬維網(wǎng)聯(lián)盟完成標(biāo)準(zhǔn)制定。 2015年,軟件開發(fā)界發(fā)生了很多變化。有很多流行的新語言發(fā)布了,也有很多重要的框架和工具發(fā)布了新版本。下面有一個(gè)我們覺得最重要的簡短清單,同時(shí)也有我們覺...
摘要:年,軟件開發(fā)界發(fā)生了很多變化。六數(shù)據(jù)存儲是一個(gè)關(guān)系型數(shù)據(jù)庫管理系統(tǒng),由瑞典公司開發(fā),目前屬于旗下公司。最流行的關(guān)系型數(shù)據(jù)庫管理系統(tǒng),在應(yīng)用方面是最好的,關(guān)系數(shù)據(jù)庫管理系統(tǒng)應(yīng)用軟件之一。七是最新的修訂版本,年月由萬維網(wǎng)聯(lián)盟完成標(biāo)準(zhǔn)制定。 2015年,軟件開發(fā)界發(fā)生了很多變化。有很多流行的新語言發(fā)布了,也有很多重要的框架和工具發(fā)布了新版本。下面有一個(gè)我們覺得最重要的簡短清單,同時(shí)也有我們覺...
閱讀 1334·2023-04-26 00:10
閱讀 2433·2021-09-22 15:38
閱讀 3786·2021-09-22 15:13
閱讀 3512·2019-08-30 13:11
閱讀 652·2019-08-30 11:01
閱讀 3035·2019-08-29 14:20
閱讀 3214·2019-08-29 13:27
閱讀 1730·2019-08-29 11:33