对于大多数初学者来说,他们更注重程序的结果.的确.好的算法的前提一定是正确.所以对于他们很愿意去看一些基础教程.所以很多知识有的教程很少讲,有的教程基本不讲.象C++的容器.内置变量的直接初始化.......
代码优化就更被大多数初学者所忽略,毕竟能作出正确的结果对于他们是最大的希望.并没有考虑什么效率.
举2个例子,
<1>有2个语句(如果有int x;)
1.x=x+1;
2.x+=1;
这两个语句是完成同样的功能
如果非要说出效率的好与坏,对于初学的同学往往束手无策.
下面我简单说一下:第1个语句从内存存取的角度来看x做了2次运算,第一次做为右操作数,第2次作为左操作数.即先找到X的地址里的内容.加1后,再次找到X的地址将结果存放到X地址中.
第2个语句从内存存取的角度看好于第一个.它找到X地址中的内容将他加1直接放在X的地址中.X只进行了一次计算!
在举个简单的例子.如果有(int m;)
1.m++;
2.++m;
他们是有区别的往往尽量使用后置.因为他的效率更高.2里的前置只需要找到X地址的内容加1即可.而m++后置操作符首先保存操作数m的值,以便返回未加1之前的值作为结果.在使X地址中的内容加1.
其实大家都能说出M++和++M的区别.但希望大家能更深入的去学习他底层的东西,不要总看基础书.多看一些外国书,因为他们总是讲的很深入很底层,希望大家能认识到这一点.不要以为看完基础教程就算完事了,如果你真的想学精与其在论坛里问别人如何进阶,不如去多看看外国书,多看看别人的技术BLOG...
祝福大家,和每一个热爱编程的人.