對C語言中自增自減運(yùn)算的剖析_第1頁
對C語言中自增自減運(yùn)算的剖析_第2頁
對C語言中自增自減運(yùn)算的剖析_第3頁
對C語言中自增自減運(yùn)算的剖析_第4頁
對C語言中自增自減運(yùn)算的剖析_第5頁
已閱讀5頁,還剩18頁未讀 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

1、對C語言中自增自減運(yùn)算的剖析1 導(dǎo)讀運(yùn)算符多、操作靈活是C語言的一大特色。在諸多的運(yùn)算符中,最容易出錯的便是自增自減運(yùn)算符。C語盲允許在一個表達(dá)式中使用兩個以上的賦值類運(yùn)算。這種靈活性使程序簡潔,但同時也會帶來副作用。本文以VC6.0編譯系統(tǒng)為標(biāo)準(zhǔn),詳解C語言中的自增自減運(yùn)算符,以期達(dá)到正確的運(yùn)用。2自增自減運(yùn)算符的基本概念3自增運(yùn)算符是+,其作用是使變量增加1。 自減運(yùn)算符是-,其作用是使變量減小1。有兩種形式前置式與后置式: 前置式:+i,先增加i再使用變量i。 后置式:i+,先使用變量i再增加i。 4注意事項51.自增自減運(yùn)算符只用于變量,不能用于常量或表達(dá)式。原因:自增、自減運(yùn)算符具有

2、對運(yùn)算量重新賦值的功能,而常量、表達(dá)式無存儲單元,當(dāng)然不能做自增、自減運(yùn)算。舉例:10+,(a+b)+都是都是不合法的。 i+j+ 是合法的,+i+j是不合法的。 因為C語言規(guī)定,從左到右盡可能多的將字符組合成運(yùn)算符,所以i+j+也就是(i+)+(j+),是合法的。而+i+j也就是+(i+)+j,第一個+作用到表達(dá)式(i+)上,因此是不合法的。62.自增自減運(yùn)算符的結(jié)合方向是從右向左(右結(jié)合性) 運(yùn)算符的結(jié)合性指同一優(yōu)先級的運(yùn)算符在表達(dá)式中操作的組織方向, 即當(dāng)一個運(yùn)算對象兩側(cè)運(yùn)算符的優(yōu)先級別相同時, 運(yùn)算對象與運(yùn)算符的結(jié)合順序, C 語言規(guī)定了各種運(yùn)算符的結(jié)合方向( 結(jié)合性) 。大多數(shù)運(yùn)算符

3、結(jié)合方向是“自左至右”, 例如a- b+c, b 兩側(cè)有- 和+兩種運(yùn)算符的優(yōu)先級相同, 按先左后右結(jié)合方向, b 先與減號結(jié)合, 執(zhí)行a- b 的運(yùn)算, 再執(zhí)行加c 的運(yùn)算。除了自左至右的結(jié)合性外, C 語言有三類運(yùn)算符參與運(yùn)算的結(jié)合方向是從右至左。即: 單目運(yùn)算符, 條件運(yùn)算符, 以及賦值運(yùn)算符。73.自增自減運(yùn)算符的優(yōu)先級是2,僅次于括號等優(yōu)先級為1的算符,高于乘除等優(yōu)先級為3的算符。優(yōu)先級為2的一系列運(yùn)算符都是右結(jié)合性的。舉例:例如當(dāng)i=6 時, 求- i+的值和i 的值。由于“- ”(負(fù)號) “+”為同一個優(yōu)先級,這個優(yōu)先級是右結(jié)合性的,故應(yīng)理解為- (i+), 又因是后置加, 所以

4、先有-i+的值為-6, 然后i自增為7。又如+i*i+,由于+優(yōu)先級高于*,故等效于( +i)*(i+)。8同一表達(dá)式中多次出現(xiàn)自增自減的問題9問題:請寫出輸出結(jié)果 int i=3; int j=3; int a = i+ + i+; int b = +j + +j; printf(%d, %dn, a, b);10例1解析這個問題比較混亂:i+ + i+: 先自增一次,相加,再自增,得到4+4=8 先相加,然后自增兩次,得到3+3=6+j + +j: 先自增一次作為被加數(shù),再自增一次作為加數(shù),得到4+5=9 先自增兩次,再相加,得到5+5=1011例1解析事實上,不同編譯系統(tǒng)有著不同的規(guī)定,

5、可能得到不同的答案。此處僅限于VC6的標(biāo)準(zhǔn)。在VC6中輸入上述代碼,可得到答案是:6,10這就需要我們對自增自減運(yùn)算符的具體運(yùn)算過程進(jìn)行詳細(xì)分析12例1解析i+的應(yīng)該是執(zhí)行完整個表達(dá)式的其他操作后,然后才自增,所以例子中的a336+j是先自增然后再參加其它運(yùn)算,所以b6612但是此時3個以上運(yùn)算符的理解仍不明確,我們再看個例子。13例2 int i=3; int j=4; int a = i+ + i+ + i+; int b = +j + +j + +j; printf(%d, %dn, a, b);這個程序的結(jié)果又是什么呢?14例2解析事實上,電腦在進(jìn)行運(yùn)算時,是運(yùn)用棧的數(shù)據(jù)結(jié)構(gòu)進(jìn)行運(yùn)算。

6、簡言之,就是“從左到右,能算就算”,而在運(yùn)算時引用的變量是當(dāng)前內(nèi)存里的值。例1中+j + +j應(yīng)該這樣理解:先運(yùn)行+j,這時j=4,棧里存變量名“j”,再運(yùn)行+j,這時j=5,棧里已經(jīng)有兩個j了,而且此時已經(jīng)可以運(yùn)算,故結(jié)果是5+5=10。i+ + i+ 應(yīng)該理解為2個i相加得6,然后i自增兩次。15例2解析仿照上述過程計算+j + +j + +j: 首先,j自增一次得到5,棧里存變量名j。然后j再自增一次得6,這時可以計算j+j,得12。然后j再自增一次得7,再計算加法,得12+7=19對于i+ + i+ + i+,按照上述理解,應(yīng)該是3+3+3=9。事實上,在VC6中輸入上述代碼,就是得到

7、9和19。這說明我們的理解是正確的。16例2解析+j + +j + +j的具體過程可以參見匯編代碼(不懂的可略過):mov ecx,dword ptr ebp-8add ecx,1mov dword ptr ebp-8,ecx / 第一個+jmov edx,dword ptr ebp-8add edx,1mov dword ptr ebp-8,edx / 第二個+jmov eax,dword ptr ebp-8add eax,dword ptr ebp-8 / +j + +j mov ecx,dword ptr ebp-8add ecx,1mov dword ptr ebp-8,ecx / 第

8、三個+jadd eax,dword ptr ebp-8 / +j + +j + +jmov dword ptr ebp-10h,eax / 賦值給b17例2解析a = i+ + i+ + i+的匯編代碼: mov eax,dword ptr ebp-4 add eax,dword ptr ebp-4 / i+i add eax,dword ptr ebp-4 / i+i+i mov dword ptr ebp-0Ch,eax / 賦值給a mov ecx,dword ptr ebp-4 add ecx,1 mov dword ptr ebp-4,ecx / 第一次i+ mov edx,dwor

9、d ptr ebp-4 add edx,1 mov dword ptr ebp-4,edx / 第二次i+ mov eax,dword ptr ebp-4 add eax,1 mov dword ptr ebp-4,eax / 第三次i+18例3int i=3,a;a=(i+)+(+i)+(i+);printf(“%dn”,a); 請寫出運(yùn)行結(jié)果19例3解析此處是前置與后置的混合使用,但只要記住后置式最后再自增,以及“從左到用,能算就算”的運(yùn)算法則,就能得出正確答案。當(dāng)運(yùn)行到第二項時,i自增得到4,然后運(yùn)行兩次加法,所以原題答案應(yīng)該是: 4+4+4=12。20總結(jié)21總結(jié)語言簡潔,代碼占內(nèi)存小,程序執(zhí)行效率高,是C語言的優(yōu)點。正確掌握自增自減運(yùn)算符的使用方法,在程序設(shè)

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論