C++的string连接(a = a + b 与 a += b)
大一学习C语言的时候,书上就写着a = a + b与 a += b等价,但是提倡用后者。
在CSDN上也看到一个关于a+=b和a=a+b的区别的帖子,大概内容如下:
------------------------------------------------------------------------------------------------------------------------------------------
楼主:为什么要强调使用 a+=b 而不建议使用a=a+b
我想在编译上应该是一样的啊
add a b
就算是间接寻址也应该一样啊
以下是各位高人的回答:
1 楼mLee79()回复于 2006-11-15 21:14:23 得分 0
打字快些,鉴定完毕 ...
6 楼wanfustudio(雁南飞:知识之败,慕虚名而不务潜修也)回复于 2006-11-15 22:03:26 得分 1
a+=b 这个性能高
作了优化
33 楼miniplayer(为了我的公主)回复于 2006-11-16 10:47:55 得分 0
少打一个a
故节省时间
41 楼Darc(注册真烦)回复于 2006-11-16 12:58:43 得分 0
可以少打一个a.
好处显而易见,第一,Coding速度提高一点点。第二,延长键盘上“A”键的寿命。
----------------------------------------------------------------------------------------------------------------------------------------------
今天在运行一段C++程序的时候,发现效率很低,经过不断的测试,最后发现是循环中的字符串连接(直接使用的a = a + b形式的连接方式)消耗了程序运行的大部分时间,上网查了一下C++中string的方法,有4种方法向string后面加字符和字符串(string a, b):
1. a = a + b;
2. a += b;
3. a.append(b);
4. push_back(); //这个的用法暂时还没去看。
然后我写了一个小程序来测试前三种方法的执行效率:
-------------------------------------------------------------------------------------------------------------------------------------------
string s1,s2,s3;
string str = "abc";
cout << "1 :" ; getTime(); //时间1,第1个函数运行开始
for(int i = 0; i < n; i++)
{
s1 = s1 + str;
}
cout << "2 :" ; getTime(); //时间2,第1个结束,第2个开始
for(int i = 0; i < n; i++)
{
s2 += str;
}
cout << "3 :" ; getTime(); //时间3,第2个结束,第3个开始
for(int i = 0; i < n; i++)
{
s3.append(str);
}
cout << "4 :" ; getTime(); //时间4,第3个函数运行结束
----------------------------------------------------------------------------------------------------------------------------------------------
当n = 100000的时候,结果如下:
[yurocy@localhost test_programme]$ ./string
1 : 2009/10/15 20:01:07
2 : 2009/10/15 20:01:10
3 : 2009/10/15 20:01:10
3 : 2009/10/15 20:01:10
第一个函数运行用了3秒钟,后面两个的时间可以忽略。
当n = 500000的时候,结果如下:
[yurocy@localhost test_programme]$ ./string
1 : 2009/10/15 20:13:00
2 : 2009/10/15 20:15:50
3 : 2009/10/15 20:15:50
3 : 2009/10/15 20:15:50
第一个函数居然用了2分50秒,后面两个的时间还是1秒以内。
当n = 1000000的时候,等了几分钟,第一个都没运行出来。
差别真是太大了。。。将程序中的 “+” 换成 “+=”,效率马上提高了好几倍。
当然,在Java里面也有这个问题,那就是String和StringBuffer的区别了。
C++的string连接(a = a + b 与 a += b)的更多相关文章
- Java中String连接性能的分析【转】
[转]http://www.blogjava.net/javagrass/archive/2010/01/24/310650.html 总结:如果String的数量小于4(不含4),使用String. ...
- Java中String连接性能的分析
总结:如果String的数量小于4(不含4),使用String.concat()来连接String,否则首先计算最终结果的长度,再用该长度来创建一个StringBuilder,最后使用这个String ...
- python string 连接test
def strTest(): name = "" for i in range(10): name += "hello" #print name def str ...
- 关于JAVA中的String的使用与连接(转)
JAVA中的String连接性能 Java中的String是一个非常特殊的类,使它特殊的一个主要原因是:String是不可变的(immutable). String的不可变性是Ja ...
- 手把手实例对比String、StringBuilder字符串的连接效率及StringBuilder和StringBuffer线程安全的比较
一.字符串连接的效率问题 使用String连接字符串时为什么慢? 小知识点 java中对数组进行初始化后,该数组所占的内存空间.数组长度都是不可变的. 创建一个字符串,为字符串对象分配内存空间,会耗费 ...
- 关于string,我今天科普的
今天下午朋友讨论组上讨论一个关于string的问题,问题是这样的,string a="aaa";string b=a;a="bbb",为什么测试b的值不改变?之 ...
- String内存陷阱简介
String 方法用于文本分析及大量字符串处理时会对内存性能造成一些影响.可能导致内存占用太大甚至OOM. 一.先介绍一下String对象的内存占用 一般而言,Java 对象在虚拟机的结构如下:•对象 ...
- jdk之String
学习几个常用的String方法 1.concat /** * Concatenates the specified string to the end of this string. 连接指定的字符串 ...
- 自己实现的string的库函数
为了更好地理解string的各个库函数,现将几个常用的库函数用自己的方式实现如下: #include<iostream> using namespace std; #include< ...
随机推荐
- 【LeetCode】Available Captures for Rook(车的可用捕获量)
这道题是LeetCode里的第999道题. 题目叙述: 在一个 8 x 8 的棋盘上,有一个白色车(rook).也可能有空方块,白色的象(bishop)和黑色的卒(pawn).它们分别以字符 &quo ...
- CSS相对布局和绝对布局
relative 相对布局,正常的,从上到下.绝对布局absolute,就像不占位置,透明了一样,会和别的重合
- HDU 4609 3-idiots ——FFT
[题目分析] 一堆小木棍,问取出三根能组成三角形的概率是多少. Kuangbin的博客中讲的很详细. 构造一个多项式 ai=i的个数. 然后卷积之后去重. 统计也需要去重. 挺麻烦的一道题. #inc ...
- P3694 邦邦的大合唱站队 (状压DP)
题目背景 BanG Dream!里的所有偶像乐队要一起大合唱,不过在排队上出了一些问题. 题目描述 N个偶像排成一列,他们来自M个不同的乐队.每个团队至少有一个偶像. 现在要求重新安排队列,使来自同一 ...
- 【2018.11.22】CTSC2018(模拟赛!)
太蠢了……$noip$ 后第一次模拟赛竟然是这样的……完全就是打击自信 / 降智…… 1. 假面 一道神仙概率 $dp$!第一次写…… 拿到题就发现血量 $m_i$ 的上限只有 $100$! 然后 $ ...
- MySQL-JDBC Loadbalance深入解析
背景说明 公司的整个电商系统搭建在华为云上,根据老总的估计,上线3个月之后日订单量会达到百万级别,保守估计3个月之后总订单个数预计会有5千万.MySQL单表达到千万级别,就会出现明显的性能问题.根据如 ...
- zoj 3627#模拟#枚举
Treasure Hunt II Time Limit: 2 Seconds Memory Limit: 65536 KB ...
- DispatcherServlet url-pattern中 /、/*、*.do中的区别与作用
DispatcherServlet url-pattern中 /./*.*.do中的区别与作用 "/'表示匹配所有请求(其中包含除.jsp和.jspx外的所有后缀). 如果不配置静态资源,它 ...
- KS103超声波测距模块
max232:电平转换芯片,将电脑的RS-232标准串口(高+12V,低-12V)转换为(高+5V,低0V). 电脑串口(RS -232) => 单片机串口(TTL串口) SIPEX SP323 ...
- 洛谷P1061 Jam的计数法
题目描述 Jam是个喜欢标新立异的科学怪人.他不使用阿拉伯数字计数,而是使用小写英文字母计数,他觉得这样做,会使世界更加丰富多彩.在他的计数法中,每个数字的位数都是相同的(使用相同个数的字母),英文字 ...