JavaScript字符串连接性能优化
2023-06-13 09:14:07 时间
varstr="hello";
str+="world";
后台所做工作:
1)创建存储"hello"的字符串,且使str指向它。
2)创建存储"world"的字符串。
3)创建存储结果的字符串。
4)将str中的当前内容复制到结果字符串中。
5)把world复制到结果字符串中。
6)更新str,使str指向结果字符串。
每拼接一次字符串就循环重复2)~6),如果重复成百上千次则会非常消耗资源,影响性能。
解决方法:
使用Array对象存储字符串,之后使用join()方法输出结果。
仿照Java中的StringBuffer类。
functionStringBuffer(){
this._strings=newArray;
}
StringBuffer.prototype.append=function(str){
this._strings.push(str);
}
StringBuffer.prototype.toString=function(){
returnthis._strings.join("");
}
测试性能:
代码1:使用"+="拼接字符串
vard=newDate();
varstr="";
for(vari=0;i<10000;i++){
str+="test";
}
vard2=newDate();
document.writeln(d2.getTime()-d.getTime());
代码2:使用StringBuffer
vard=newDate();
varstr=newStringBuffer();
for(vari=0;i<10000;i++){
str.append("test");
}
varres=str.toString();
vard2=newDate();
document.writeln(d2.getTime()-d.getTime());
从多次测试结果看来,使用StringBuffer可以节省50%以上的时间。
相关文章
- javascript_JavaScript走向成熟
- 【说站】javascript事件冒泡是什么
- javascript html转换成markdown,如何使用Turndown使用JavaScript将HTML转换为Markdown[通俗易懂]
- JavaScript 日期选择器 Pikaday 的高级用法
- JavaScript学习总结(十六)——Javascript闭包(Closure)详解编程语言
- JavaScript学习总结(九)——Javascript面向(基于)对象编程详解编程语言
- JavaScript 的性能优化:加载和执行详解编程语言
- JavaScript连接Oracle数据库配置指南(js连接oracle配置)
- 小议Function.apply()之二------利用Apply的参数数组化来提高JavaScript程序性能
- JavaScript脚本性能的优化方法
- Javascript更新JavaScript数组的uniq方法
- JavaScript脚本性能优化注意事项
- JavaScript验证浏览器是否支持javascript的方法小结
- javascript获得CheckBoxList选中的数量
- JavaScript设计模式富有表现力的Javascript(一)
- 13个JavaScript性能提升技巧分享
- JavaScript高级程序设计阅读笔记(十六)javascript检测浏览器和操作系统-detect.js
- JavaScript的常见兼容问题及相关解决方法(chrome/IE/firefox)
- 减少访问DOM的次数提升javascript性能
- 脚本合并提升javascript性能示例
- 使用JavaScript判断图片是否加载完成的三种实现方式
- JavaScript跨域方法汇总
- 关于编写性能高效的javascript事件的技术
- Javascript学习指南