js配列のforループの書き方は? _JavaScript スキル

WBOY
リリース: 2016-05-16 18:26:08
オリジナル
1160 人が閲覧しました

それでは、今日私がどの権威を疑い始めたかを見てみましょう。 。 。

私がプログラミングを学び始めて以来、そして配列に触れて以来、さまざまな場所やさまざまな時間で、私に注意を促す人々を常に見かけてきました。配列をトラバースするために for を使用する場合は、for を使用する必要があります。 for(var i=0;i>arr.length;i) の代わりに (var i= 0,n=arr2.length;i
ああ?言語が異なれば実装も異なる可能性があるため、ここでは他のプログラミング言語については説明しません。他の言語でどのような状況になるかは人それぞれです。 実は、上記のいわゆる「考えればわかる」というのは、みんながよく考えたり、実際に試したりせずに、ただ頭の中で考えているだけなのかもしれません。さて、よく考えてみましょう。最初の書き方は本当に 2 番目の書き方より速いのでしょうか? arr.length は CPU を大量に消費しますか?いいえ、なぜ CPU を消費するのでしょうか? arr.length はメソッドを呼び出しませんが、配列の長さ属性を読み取るだけです。ネイティブ属性を読み取るのと、定義された変数を読み取るのはどちらが速いと思いますか? 長さを読む方が速いと思ったので、アイデアをテストするためにテストを書きました。独自の小さなテスト フレームワークを使用しました。

コードをコピー コードは次のとおりです:

var arr=[], arr2=[],i=0
while(iarr.push ( i)
arr2.push(i)
i
}
M.TA.begin("0000")
for(var i=0;iarr[i]=arr[i]*arr[i]*arr[i]
}
M.TA.end("0000","for(var i=0; i< ;arr.length;i )")
M.TA.begin("0001");
for(var i=0,n=arr2.length;i arr2 [i]=arr2[i]*arr2[i]*arr2[i]
}
M.TA.end("0001"," for(var i=0,n=arr2.length; iM.TA.showResult()

もちろん、このコードは非常に異常で、300 メガバイト以上のメモリを消費します。 結果は次のとおりです:
chrome
js配列のforループの書き方は? _JavaScript スキル
firefox
js配列のforループの書き方は? _JavaScript スキル
(N 種類のパフォーマンス テストを行った結果、Firefox は基本的な点で chrome よりもはるかに効率的であることがわかりました)
ie8
js配列のforループの書き方は? _JavaScript スキル
(N 桁削減後のデメリット。上記のスクリプトは ie では実行できません)
概要: ?
実際には、このテストは、for(var i=0;i
実は私はまだ権威を尊重しているので、これを書いているとき、私はまだどこかで間違っていたのではないかと心配しています。そうだったら、みんな笑って済ませばいいのに、そうでないなら、ついに犬っぽいブログ記事を書いてしまった。 。 。
転載メモ:
http://www.html-js.com

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート