JavaScript 學習筆記(七)字符串的連接
更新時間:2009年12月31日 23:22:30 作者:
javascript 字符串的連接效率問題,需要的朋友可以參考下。
字符串的連接
一、 最常用+=
一直說這種方式的效率是最低的,為什么呢?可以看下這種方式的實質(zhì)過程。
var str = "hello";
str += "world";
(1) 創(chuàng)建存儲"hello"的字符串。
(2) 創(chuàng)建存儲"world"的字符串。
(3) 創(chuàng)建存儲連接結(jié)果的字符串。
(4) 把str的當前內(nèi)容復制到結(jié)果中。
(5) 把"world"復制到結(jié)果中。
(6) 更新str,使它指向結(jié)果。
每次完成字符串連接都會執(zhí)行步驟2到6,使得這種操作非常消耗資源。如果重復這一過程幾百次,甚至幾千次,就會造成性能問題。所有以后就要摒棄這種用法了,哈哈哈。^_^
二、 join()方法
//按鈕調(diào)用
function JoinFn() {
var arr = new Array;
arr[0] = "張三";
arr[1] = "李四";
alert(arr.join(""));
}
執(zhí)行的步驟如下:
(1) 創(chuàng)建存儲結(jié)果的字符串。
(2) 把每個字符串復制到結(jié)果中的合適位置。
這中方法效率比第一種快。
三、 封裝一個自定義的類
JavaScript中沒有像C#中那樣的StringBuilder類,但是我們可以自定義一個StringBuilder類,建類的方法就是上一篇提到的“混合的構(gòu)造函數(shù)/原型方式”。
//自定義一個StringBuilder類,用來連接字符串
function StringBuilder() {
this._strings = new Array();
}
StringBuilder.prototype.append = function(str) {
this._strings.push(str);
};
StringBuilder.prototype.toString = function() {
return this._strings.join("");
};
//按鈕調(diào)用
function MyConnectClassFn() {
var sb = new StringBuilder();
sb.append("張三");
sb.append("李四");
var strResult = sb.toString();
alert(strResult);
}
總結(jié)
最后比較以上這三種方法,書上說最后一種速度最快,但是經(jīng)過我測試,貌似join()是最快的,第三種反而是最慢的,難道我的自定義StringBuilder類有問題?
一、 最常用+=
一直說這種方式的效率是最低的,為什么呢?可以看下這種方式的實質(zhì)過程。
var str = "hello";
str += "world";
(1) 創(chuàng)建存儲"hello"的字符串。
(2) 創(chuàng)建存儲"world"的字符串。
(3) 創(chuàng)建存儲連接結(jié)果的字符串。
(4) 把str的當前內(nèi)容復制到結(jié)果中。
(5) 把"world"復制到結(jié)果中。
(6) 更新str,使它指向結(jié)果。
每次完成字符串連接都會執(zhí)行步驟2到6,使得這種操作非常消耗資源。如果重復這一過程幾百次,甚至幾千次,就會造成性能問題。所有以后就要摒棄這種用法了,哈哈哈。^_^
二、 join()方法
復制代碼 代碼如下:
//按鈕調(diào)用
function JoinFn() {
var arr = new Array;
arr[0] = "張三";
arr[1] = "李四";
alert(arr.join(""));
}
執(zhí)行的步驟如下:
(1) 創(chuàng)建存儲結(jié)果的字符串。
(2) 把每個字符串復制到結(jié)果中的合適位置。
這中方法效率比第一種快。
三、 封裝一個自定義的類
JavaScript中沒有像C#中那樣的StringBuilder類,但是我們可以自定義一個StringBuilder類,建類的方法就是上一篇提到的“混合的構(gòu)造函數(shù)/原型方式”。
復制代碼 代碼如下:
//自定義一個StringBuilder類,用來連接字符串
function StringBuilder() {
this._strings = new Array();
}
StringBuilder.prototype.append = function(str) {
this._strings.push(str);
};
StringBuilder.prototype.toString = function() {
return this._strings.join("");
};
//按鈕調(diào)用
function MyConnectClassFn() {
var sb = new StringBuilder();
sb.append("張三");
sb.append("李四");
var strResult = sb.toString();
alert(strResult);
}
總結(jié)
最后比較以上這三種方法,書上說最后一種速度最快,但是經(jīng)過我測試,貌似join()是最快的,第三種反而是最慢的,難道我的自定義StringBuilder類有問題?
相關(guān)文章
javascript實現(xiàn)用戶點擊數(shù)量統(tǒng)計
本文主要javascript實現(xiàn)用戶點擊數(shù)量統(tǒng)計的方法進行詳細介紹,具有很好的參考價值,需要的朋友一起來看下吧2016-12-12
JavaScript+html5 canvas制作的百花齊放效果完整實例
這篇文章主要介紹了JavaScript+html5 canvas制作的百花齊放效果,結(jié)合完整實例形式分析了使用html5的canvas技術(shù)動態(tài)繪制圖形的技巧,需要的朋友可以參考下2016-01-01
JavaScript中正則表達式使數(shù)字、中文或指定字符高亮顯示
這篇文章主要介紹了JavaScript中正則表達式使數(shù)字、中文或指定字符高亮顯示,需要的朋友可以參考下2017-10-10
使用JavaScript實現(xiàn)在頁面中顯示距離2017年中秋節(jié)的天數(shù)
這篇文章主要介紹了 使用JavaScript實現(xiàn)在頁面中顯示距離2017年中秋節(jié)的天數(shù)的相關(guān)資料,需要的朋友可以參考下2017-09-09
JS面向?qū)ο缶幊獭狤S6 中class的繼承用法詳解
這篇文章主要介紹了JS面向?qū)ο缶幊獭狤S6 中class的繼承用法,結(jié)合實例形式詳細分析了ES6中class繼承的相關(guān)操作技巧與使用注意事項,需要的朋友可以參考下2020-03-03
JavaScript的null和undefined區(qū)別示例介紹
在Javascript中對于這種生命后沒有給定初始值的變量,就給他一個undefined,如果要將一個標識符聲明稱object類型,但是暫時不給他實例,那么就可以將它先初始化為null2014-09-09

