摘要:編寫高性能的翻譯自的文章。編譯器自然地希望能夠處理那些單態(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)心。
</>復(fù)制代碼
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ì)等。
</>復(fù)制代碼
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); // good
Constants:常量
使用常量能夠讓編譯器在編譯時(shí)即完成變量的值替換:
</>復(fù)制代碼
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)更好。使用字符串類型可能會帶來額外的垃圾回收消耗。
</>復(fù)制代碼
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)化:
</>復(fù)制代碼
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ù)變量:
</>復(fù)制代碼
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è)隱類。
</>復(fù)制代碼
// 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++)
</>復(fù)制代碼
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ù)傳入,也會增加性能損耗:
</>復(fù)制代碼
// 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://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
极致性价比!云服务器续费无忧!
Tesla A100/A800、Tesla V100S等多种GPU云主机特惠2折起,不限台数,续费同价。
NVIDIA RTX 40系,高性价比推理显卡,满足AI应用场景需要。
乌兰察布+上海青浦,满足东推西训AI场景需要