大一学习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)的更多相关文章

  1. Java中String连接性能的分析【转】

    [转]http://www.blogjava.net/javagrass/archive/2010/01/24/310650.html 总结:如果String的数量小于4(不含4),使用String. ...

  2. Java中String连接性能的分析

    总结:如果String的数量小于4(不含4),使用String.concat()来连接String,否则首先计算最终结果的长度,再用该长度来创建一个StringBuilder,最后使用这个String ...

  3. python string 连接test

    def strTest(): name = "" for i in range(10): name += "hello" #print name def str ...

  4. 关于JAVA中的String的使用与连接(转)

    JAVA中的String连接性能 Java中的String是一个非常特殊的类,使它特殊的一个主要原因是:String是不可变的(immutable).           String的不可变性是Ja ...

  5. 手把手实例对比String、StringBuilder字符串的连接效率及StringBuilder和StringBuffer线程安全的比较

    一.字符串连接的效率问题 使用String连接字符串时为什么慢? 小知识点 java中对数组进行初始化后,该数组所占的内存空间.数组长度都是不可变的. 创建一个字符串,为字符串对象分配内存空间,会耗费 ...

  6. 关于string,我今天科普的

    今天下午朋友讨论组上讨论一个关于string的问题,问题是这样的,string a="aaa";string b=a;a="bbb",为什么测试b的值不改变?之 ...

  7. String内存陷阱简介

    String 方法用于文本分析及大量字符串处理时会对内存性能造成一些影响.可能导致内存占用太大甚至OOM. 一.先介绍一下String对象的内存占用 一般而言,Java 对象在虚拟机的结构如下:•对象 ...

  8. jdk之String

    学习几个常用的String方法 1.concat /** * Concatenates the specified string to the end of this string. 连接指定的字符串 ...

  9. 自己实现的string的库函数

    为了更好地理解string的各个库函数,现将几个常用的库函数用自己的方式实现如下: #include<iostream> using namespace std; #include< ...

随机推荐

  1. hdu 1536 sg (dfs实现)

    S-Nim Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submi ...

  2. 【Kubernetes】离线业务:Job与CronJob

    Deployment.StatefulSet和DaemonSet这三个编排概念编排的对象主要都是在线业务(Long Running Task,这些应用一旦运行起来,除非出错或者停止,它的容器进程会一直 ...

  3. LA 并查集路径压缩

    题目大意:有n个节点,初始时每个节点的父亲节点都不存在.有两种操作 I u v:把点节点u的父亲节点设为v,距离为|u-v|除以1000的余数.输入保证执行指令前u没有父亲节点. E u:询问u到根节 ...

  4. 小Z的袜子(bzoj 2038)

    Description 作为一个生活散漫的人,小Z每天早上都要耗费很久从一堆五颜六色的袜子中找出一双来穿.终于有一天,小Z再也无法忍受这恼人的找袜子过程,于是他决定听天由命……具体来说,小Z把这N只袜 ...

  5. HNOI_2002 营业额统计(Splay)

    此题可以用STL的multiset解决,也可以手打一棵伸展树(Splay)来求前驱与后驱. 使用multiset: #include<iostream> #include<set&g ...

  6. 51 NOD 1325 两棵树的问题

    Discription 对于 100% 的数据, N<=50. solution: 发现N比较小,所以我们可以花O(N^2)的代价枚举两颗树的联通块的LCA分别是哪个点,然后现在问题就变成了:选 ...

  7. Springboot 工具类静态注入

    用springboot搭了一个项目,里面要用到一个DictUtils,因为要用到DictMapper,在百度找了一些方法,最后用下面的方法能成功获取到DictMapper @Component pub ...

  8. Linux防火墙iptables规则设置(转)

    iptables命令是Linux上常用的防火墙软件,是netfilter项目的一部分.可以直接配置,也可以通过许多前端和图形界面配置. 一.语法 iptables(选项)(参数) 二.选项 -t< ...

  9. 【Todo】ES6学习

    今天部分分享,有一篇PPT,放在这里了 /Users/baidu/Documents/Data/Work/分享资料/ES6大法好.pptx 内容挺丰富的,可以学习.

  10. chrome插件网站

    chrome插件网站 http://chromecj.com/