javascript中字符串累加的性能优化(String和StringBuffer)

简介:

在JAVA中操作N个字符串累加或许会使用:

  1. String?strs?= "";
  2. for(int i?= 0;?i<2000;?i++)?{
  3. strs?+= "my?test";
  4. }

稍微有点编程经验的可能就会使用StringBuffer类来累加字符串,例如:

  1. StringBuffer?strs?= new StringBuffer();
  2. for(int i?= 0;?i<2000;?i++)?{
  3. strs.append("my?text");
  4. }

性能大家测试一下就知道了,根据机器配置的不同时间差可能会不一样;

下面我们来看看javascript中如何使用:

在javascript中只有String对象而没有设计StringBuffer对象,那我们就来自己设计一个StringBuffer对象

  1. function StringBuffer(){
  2. this._strings_?= new Array();
  3. }
  4. StringBuffer.prototype.append?= function(str)?{
  5. this._strings_.push(str);
  6. }
  7. StringBuffer.prototype.toString?= function()?{
  8. return this._strings_.join("");
  9. }

这个StringBuffer对象只有两个方法,一个是增加字符串,一个是输出累加的字符串结果,原理就是使用数组暂存累加的字符串内容最后再做字符串的链接操作,这样就把String对象中的累加操作省掉了,下面是20000次循环后的结果:

累加字符串共消耗1218毫秒 StringBuffer共消耗188毫秒

经测试差距在4-10倍之间,效率就很明显了,呵呵

相关文章
|
8月前
|
Python
Python中的f-string:更优雅的字符串格式化
Python中的f-string:更优雅的字符串格式化
446 100
|
8月前
|
开发者 Python
Python中的f-string:高效字符串格式化的利器
Python中的f-string:高效字符串格式化的利器
609 99
|
8月前
|
Python
Python中的f-string:更优雅的字符串格式化
Python中的f-string:更优雅的字符串格式化
|
8月前
|
开发者 Python
Python f-string:高效字符串格式化的艺术
Python f-string:高效字符串格式化的艺术
|
9月前
|
Python
Python中的f-string:更简洁的字符串格式化
Python中的f-string:更简洁的字符串格式化
424 92
|
10月前
|
自然语言处理 Java Apache
在Java中将String字符串转换为算术表达式并计算
具体的实现逻辑需要填写在 `Tokenizer`和 `ExpressionParser`类中,这里只提供了大概的框架。在实际实现时 `Tokenizer`应该提供分词逻辑,把输入的字符串转换成Token序列。而 `ExpressionParser`应当通过递归下降的方式依次解析
471 14
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的客户关系管理系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的客户关系管理系统附带文章源码部署视频讲解等
416 2
|
JavaScript 前端开发
JavaScript中的原型 保姆级文章一文搞懂
本文详细解析了JavaScript中的原型概念,从构造函数、原型对象、`__proto__`属性、`constructor`属性到原型链,层层递进地解释了JavaScript如何通过原型实现继承机制。适合初学者深入理解JS面向对象编程的核心原理。
319 1
JavaScript中的原型 保姆级文章一文搞懂

热门文章

最新文章