自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

為什么說++i的效率比i++高?

開發(fā) 后端 開發(fā)工具
++i和i++這兩個(gè)表達(dá)式從我們初學(xué)編程語言的時(shí)候就會(huì)接觸到。前者是自增后取值,后者是取值后自增。不知道你是否聽說過++i比i++快的說法,真的如此嗎?

不知道你是否聽說過++i比i++快的說法,真的如此嗎?

++i與i++的區(qū)別

這兩個(gè)表達(dá)式從我們初學(xué)編程語言的時(shí)候就會(huì)接觸到。前者是自增后取值,后者是取值后自增。

我們看一個(gè)簡單的例子。

  1. #include <iostream> 
  2. using namespace std; 
  3. int main() 
  4.     int a = 0
  5.     int b = 0
  6.     int c = a++;//int tmp = a;c=a;aa = a + 1 
  7.     int d = ++b;//bb = b + 1;d = b
  8.     cout<<"c="<<c<<";d="<<d<<endl
  9.     return 0; 

運(yùn)行結(jié)果:

  1. c=0;d=1   

對于這個(gè)結(jié)果我們并不感到意外。

另外我們還注意到另外一個(gè)有意思的現(xiàn)象:

  1. #include <iostream> 
  2. using namespace std; 
  3. int main() 
  4.     int a = 0
  5.     int b = 0
  6.     int *c = &(a++); 
  7.     int *d = &(++b); 
  8.     return 0; 

編譯后報(bào)錯(cuò):

  1. main.cpp:7:19: error: lvalue required as unary ‘&’ operand 
  2.      int *c = &(a++); 

說&作用于左值,也就是說a++的結(jié)果并非左值。但++b的結(jié)果是左值。

可簡單理解左值和右值:

  • 左值,有名對象,可賦值
  • 右值,臨時(shí)對象,不可被賦值

運(yùn)算符重載

通過前面的例子也發(fā)現(xiàn)了,對于內(nèi)置類型,前置自增返回對象的引用,而后置自增返回對象的原值(但非左值)。

基于上述原則,一個(gè)前置版本和后置版本的常見實(shí)現(xiàn)如下:

  1. class Test 
  2. public: 
  3.     Test& operator++();//前置自增 
  4.     const Test operator++(int);//后置自增 
  5. private: 
  6.     int curPos; //當(dāng)前位置 
  7. }; 
  8. /*前置自增實(shí)現(xiàn)范式*/ 
  9. Test& Test::operator++() 
  10.     ++curPos;      //自增 
  11.     return *this;  //取值 
  12. /*后置自增實(shí)現(xiàn)范式,為了與前置區(qū)分開,多了一個(gè)int參數(shù),但從來沒用過*/ 
  13. const Test Test::operator++(int) 
  14.     Test tmp = *this;  //取值 
  15.     ++curPos;             //自增 
  16.     return tmp; 

仔細(xì)觀察后,我們發(fā)現(xiàn)前置自增,先自增,后返回原對象的對象;沒有產(chǎn)生任何臨時(shí)對象;而后置自增,先保存原對象,然后自增,最后返回該原臨時(shí)對象,那么它就需要?jiǎng)?chuàng)建和銷毀,這樣一來,效率孰高孰低就很清楚了。

在不進(jìn)行賦值的情況下,內(nèi)置類型前置和后置自增的匯編都是一樣的呢!

  1. void test() 
  2.   int i = 0
  3.   i++; 
  4.   //++i; 

匯編:

  1. push    rbp 
  2. mov     rbp, rsp 
  3. mov     DWORD PTR [rbp-4], 0 
  4. add     DWORD PTR [rbp-4], 1 
  5. nop 
  6. pop     rbp 
  7. ret 

不過,賦值的情況下,并且不開啟編譯器優(yōu)化,它們的匯編代碼還是有差別的,有興趣的可以試試。

總結(jié)

對于內(nèi)置類型,前置和后置自增或者自減在編譯器優(yōu)化的情況下,兩者并無多大差別,而對于自定義類型,如無特別需要,人們似乎更加偏愛前置自增或自減,因?yàn)楹笾米栽龀3?huì)產(chǎn)生臨時(shí)對象。

但是,又能提高多少效率呢?

 

責(zé)任編輯:趙寧寧 來源: 編程珠璣
相關(guān)推薦

2021-08-02 09:31:20

Python工具代碼

2021-11-24 07:56:56

For i++ ++i

2024-01-31 23:47:17

i++++i編碼

2020-07-09 09:56:48

Python語言開發(fā)

2016-12-14 12:02:01

StormHadoop大數(shù)據(jù)

2017-02-14 14:20:02

StormHadoop

2022-05-10 15:59:44

split lock虛擬化

2021-10-13 06:49:15

網(wǎng)絡(luò) IO

2022-09-23 10:58:44

谷歌員工生產(chǎn)力大O表示

2014-03-27 15:01:50

算法C++

2021-05-12 08:15:53

HTTPSHTTP安全

2020-07-22 08:01:41

Python開發(fā)運(yùn)算符

2020-07-16 15:20:13

switch...caif...else語言

2023-09-28 08:21:20

i++++i高并發(fā)

2017-12-19 16:24:20

2017-12-28 14:39:06

電腦IO

2015-08-26 10:37:13

云主機(jī)物理機(jī)服務(wù)器故障

2020-02-24 12:34:21

JuliaPython編程語言

2023-09-03 22:44:28

I/O高并發(fā)

2013-05-16 11:34:27

Google蘋果
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號