c++拼接字符串效率比较(+=、append、stringstream、sprintf)
转自:http://www.cnblogs.com/james6176/p/3222671.html
c++拼接字符串效率比较(+=、append、stringstream、sprintf)
最近写的程序用到大量拼接字符串,为了提高拼接效率,比较了一下+=、append、stringstream、sprintf四种拼接字符串的方法。
测试方法
比较方法是写了4个函数,分别用+=、append、stringstream、sprintf的方式来拼接字符串,拼接方法是将 s1="abcedfg",s2="hijklmn",s3="opqrst"三个字符串拼接到一起,总共循环60次。然后在main函数中依次调用这4 个函数,并打时间戳来计时。为了使时间差异更明显,可以取循环N(N可以为100或是1000000等)次调用的时间。代码如下:

1 #include <iostream>
2 #include <string>
3 #include <sys/time.h>
4 #include <sstream>
5 #include <stdio.h>
6 using namespace std;
7 #define OUT_IN_REPEATE_NUM 10000
8 #define IN_REPEATE_NUM 60
9
10 string s1="abcedfg";
11 string s2="hijklmn";
12 string s3="opqrst";
13 void plusTest(string& ret)
14 {
15 for(int i=0; i<IN_REPEATE_NUM; i++)
16 {
17 ret += s1;
18 ret += s2;
19 ret += s3;
20 }
21 }
22 void appendTest(string& ret)
23 {
24 for(int i=0; i<IN_REPEATE_NUM; i++)
25 {
26 ret.append(s1);
27 ret.append(s2);
28 ret.append(s3);
29 }
30 }
31 void sprintfTest(string& ret)
32 {
33 const size_t length=26*IN_REPEATE_NUM;
34 char tmp[length];
35 char* cp = tmp;
36 size_t strLength=s1.length()+s2.length()+s3.length();
37 for(int i=0; i<IN_REPEATE_NUM; i++)
38 {
39 sprintf(cp,"%s%s%s", s1.c_str(), s2.c_str(),s3.c_str());
40 cp+=strLength;
41 }
42 ret = tmp;
43 }
44
45 void ssTest(string& ret)
46 {
47 stringstream ss;
48 for(int i=0; i<IN_REPEATE_NUM; i++)
49 {
50 ss<<s1;
51 ss<<s2;
52 ss<<s3;
53 }
54 ret = ss.str();
55 }
56 int main() {
57 string ss, plus, append, sprintf;
58 struct timeval sTime, eTime;
59
60 gettimeofday(&sTime, NULL);
61 for(int i=0; i<OUT_IN_REPEATE_NUM; i++)
62 {
63 sprintf="";
64 sprintfTest(sprintf);
65 }
66 gettimeofday(&eTime, NULL);
67 long SprintfTime = (eTime.tv_sec-sTime.tv_sec)*1000000+(eTime.tv_usec-sTime.tv_usec); //exeTime 单位是微秒
68
69 gettimeofday(&sTime, NULL);
70 for(int i=0; i<OUT_IN_REPEATE_NUM; i++)
71 {
72 append="";
73 appendTest(append);
74 }
75 gettimeofday(&eTime, NULL);
76 long AppendTime = (eTime.tv_sec-sTime.tv_sec)*1000000+(eTime.tv_usec-sTime.tv_usec); //exeTime 单位是微秒
77
78 gettimeofday(&sTime, NULL);
79 for(int i=0; i<OUT_IN_REPEATE_NUM; i++)
80 {
81 ss="";
82 ssTest(ss);
83 }
84 gettimeofday(&eTime, NULL);
85 long SsTime = (eTime.tv_sec-sTime.tv_sec)*1000000+(eTime.tv_usec-sTime.tv_usec); //exeTime 单位是微秒
86
87 gettimeofday(&sTime, NULL);
88 for(int i=0; i<OUT_IN_REPEATE_NUM; i++)
89 {
90 plus="";
91 plusTest(plus);
92 }
93 gettimeofday(&eTime, NULL);
94 long PlusTime = (eTime.tv_sec-sTime.tv_sec)*1000000+(eTime.tv_usec-sTime.tv_usec); //exeTime 单位是微秒
95
96 cout<<"PlusTime is : "<<PlusTime<<endl;
97 cout<<"AppendTime is : "<<AppendTime<<endl;
98 cout<<"SsTime is : "<<SsTime<<endl;
99 cout<<"SprintfTime is :"<<SprintfTime<<endl;
100 if(ss==sprintf && append==plus && ss==plus)
101 {
102 cout<<"They are same"<<endl;
103 }
104 else
105 {
106 cout<<"Different!"<<endl;
107 cout<<"Sprintf: "<<sprintf<<endl;
108 cout<<"ss: "<<ss<<endl;
109 cout<<"Plus: "<<plus<<endl;
110 cout<<"Append:"<<append<<endl;
111 }
112
113 }

测试结果:
在Linux环境下用g++编译以上代码,运行结果如下(时间单位为μm):
外层循环1000000次 |
外层循环100000次 |
外层循环10000次 |
外层循环1000次 |
外层循环100次 |
PlusTime is : 3405450 AppendTime is : 4020078 SsTime is : 7835499 SprintfTime is : 14875433 They are same |
PlusTime is : 337229 AppendTime is : 401719 SsTime is : 788242 SprintfTime is : 1517999 They are same |
PlusTime is : 32177 AppendTime is : 40265 SsTime is : 78928 SprintfTime is : 150839 They are same |
PlusTime is : 3402 AppendTime is : 4074 SsTime is : 7984 SprintfTime is : 15425 They are same |
PlusTime is : 369 AppendTime is : 429 SsTime is : 921 SprintfTime is : 1591 They are same |
结论:
根据以上结果,如果是使用Linux系统并且是g++(gcc)编译器,大量拼接字符串的效率从高到低依次为:+=、append()、stringstream、sprintf()。
——菜鸟吉姆斯原创,如有错误,敬请指正!
c++拼接字符串效率比较(+=、append、stringstream、sprintf)的更多相关文章
- String拼接字符串效率低,你知道原因吗?
面试官Q1:请问为什么String用"+"拼接字符串效率低下,最好能从JVM角度谈谈吗? 对于这个问题,我们先来看看如下代码: public class StringTest { ...
- java 几种拼接字符串的效率问题
拼接字符串,大致有3个class可以用,他们是String, StringBuffer,StringBuilder, StringBuilder是1.5中来代替StringBuffer的.检验方法如下 ...
- 谈JavaScript组合拼接字符串的效率 --转载
JavaScript组合拼接字符串的效率.在脚本开发过程中,经常会按照某个规则,组合拼接出一个大字符串进行输出.比如写脚本控件时控制整个控件的外观的HTML标签输出,比如AJAX里得到服务器端的回传值 ...
- Golang拼接字符串的5种方法及其效率_Chrispink-CSDN博客_golang 字符串拼接效率 https://blog.csdn.net/m0_37422289/article/details/103362740
Different ways to concatenate two strings in Golang - GeeksforGeeks https://www.geeksforgeeks.org/di ...
- Lua大量字符串拼接方式效率对比及原因分析
Lua大量字符串拼接方式效率对比及原因分析_AaronChan的博客-CSDN博客_lua字符串拼接消耗 https://blog.csdn.net/qq_26958473/article/detai ...
- Sql动态查询拼接字符串的优化
Sql动态查询拼接字符串的优化 最原始的 直接写:string sql="select * from TestTables where 1=1";... 这样的代码效率很低的,这样 ...
- C# 拼接字符串的几种方式和性能
开发过程中常用到的拼接字符串的方法有三种: 1 简单 “+=” 拼接法 1 2 3 4 5 string str="a"; str+="c"+"d ...
- StringBuilder(拼接字符串省内存)
观察如下代码: String s = ""; for (int i = 0; i < 1000; i++) { s = s + "," + i; } 虽然 ...
- 昨天还在for循环里写加号拼接字符串的那个同事,今天已经不在了
引言 都说 StringBuilder 在处理字符串拼接上效率要强于 String,但有时候我们的理解可能会存在一定的偏差.最近我在测试数据导入效率的时候就发现我以前对 StringBuilder 的 ...
随机推荐
- Python天天美味(15) - Python正则表达式操作指南(re使用)(转)
http://www.cnblogs.com/coderzh/archive/2008/05/06/1185755.html 简介 Python 自1.5版本起增加了re 模块,它提供 Perl 风格 ...
- like 大数据字段 查询慢
对于ntext的字段,作为查询条件的时候速度会很慢,比如以下语句: select * from T_KNOWLEDGE where CONTENTS like '%Oracle TimesTen In ...
- 移动wabAPP 开发 viewport 注意事项
我们在开发移动设备的网站时,最常见的的一个动作就是把下面这个东西复制到我们的head标签中: <meta name="viewport" content="widt ...
- 通过web代理进行跨域访问,http请求返回超时的问题定位
[现象] 在ajax通过web代理跨域访问时,http第一次登陆时正常,但是第二次再下发其他命令的时候总是返回 java.net.SocketTimeoutException: Read timed ...
- Qt之启动外部程序(调用cmd.exe ping putty winscp 管道等等,比较牛叉)
http://blog.csdn.net/u011012932/article/details/50478833
- 如何将sql server数据库转化成sqlite数据库
今天在将sql server转化为sqlite的数据库的时候,遇到不少的问题,在网上搜了很长时间,都没有找到合适的软件将sql server转化成sqlite,其中用到了SqliteDev软件,在转化 ...
- swap chain- IDirect3DSwapChain9
交换链,对应的接口是IDirect3DSwapChain9,是整个Directx 3D中最核心的接口.D3d程序至少包含一个swap chain,在调用CreateDevice时自动创建, 其中的D3 ...
- 126. Word Ladder II
题目: Given two words (beginWord and endWord), and a dictionary's word list, find all shortest transfo ...
- Android ActionBar隐藏修改图标和标题
有时候在一些子页面或者内容页面,不需要显示ActionBar的标题栏图标.可用如下方式进行设置. 首先获取到ActionBar对象 ActionBar actionBar=getActionBar() ...
- JVM内存管理(二)
JVM内存管理 JVM在执行java程序的过程中,会把内存划分为若干个不同的数据区域.这些区域都有各自的用途,以及创建和销毁的时间,有的区域随着虚拟机进程的启动而存在,有些区域则依赖 ...