1樓:匿名使用者
自增分字首自增和字尾自增。無論是什麼,執行自增都有1個***,就是原來變數的值會增加1。例如int a=1;a++;或int a=1;++a;執行後,a==2。
而他們的區別就在於整個自增表示式的值不同。如(a++)的值是變數a自增以前的值,如上面例子,(a++)==1。而(++a)的值則是變數a自增以後的值,即(++a)==1+1==2。
結合性分為左結合和右結合,只有優先順序相同時才看結合性,例如表示式a+b*c+d-e*f,因為乘法優先級別高於加減,所以a+(b*c)+d-(e*f),又因+-運算是左結合,所以只a+(b*c)再(a+(b*c))+d再(a+(b*c)+d)-(e*f),假如是右結合,就先d-(e*f),也就反過來了。這裡其實看不出有什麼區別,怎麼樣結果都一樣。
但看到*p++運算就不同了,因為*與++運算同一優先順序,左結合結果就是(*p)++,右結合就是*(p++),這是區別很大的,書上還很多例子,你可以自己去看的。
強制轉換問題就是在可以轉換的情況下按要求轉換。如float x=9.9;
則(int)x==9。將實型轉為整型是採用截掉小數部分的做法。
例如還可以整型轉字元常量等等,例如,int a=97;則(char)a=='a',因為字元a的ascll碼為97。
()裡面即是你要轉換的型別。
2樓:匿名使用者
通俗點吧,自增就是加1,分字首自增和字尾自增,字首自增就是先讓自己加1然後再使用,字尾自增就是先使用,然後這個原來的值加1,字尾自減也是如此
3樓:匿名使用者
a++等價於a=a+1;先賦值後做加1操作;
a--等價於a=a-1;先賦值後做減1操作;
++a等價於a=a+1;先做加1操作後賦值;
--a等價於a=a-1;先做減1操作後賦值;;
4樓:匿名使用者
a++,a--
++a,--a
a+=,a-=
都算作自加自減,在具體使用下和普通的+-法沒有很大的區別,但是執行速度更快
c語言的自增自減問題
5樓:勿忘心安
計算:從右往左,並輸出到「緩衝區」。
1、緩衝區是一堆疊
2、第一步:處理後面的「i--」。8進入緩衝區,i=7。緩衝區:8 <-(指標)
第二步:處理「i++」。7進入緩衝區,i=8。
緩衝區:7 8<-第三步:處理」--i「。
8進入緩衝區,i=7.緩衝區:8 7 8第四步:
處理「++i」 先自增1,然後8進入緩衝區,i=8 .緩衝區: 8 8 7 8
3、輸出緩衝區資料(棧規則):8 8 7 8另外自增 、自減 、還可能和編譯器有關係 。
6樓:匿名使用者
函式引數的求值順序是自右向左」更是大錯特錯。樓主,c語言跟大多數語言一樣,沒有規定表示式的求值順序,除了以下幾個順序點:
;(分號,標誌一條語句結束)
,(逗號操作符,函式引數列表裡面的逗號只起分隔作用,不是逗號操作符)
&&和||(邏輯與,邏輯或)
? : (條件運算子)
()(if,while,for, do..while,以及函式呼叫)
這些統稱為順序點,它們的求值順序有規定。我這裡只給你說明逗號操作符,其他的不一一作介紹(不然能寫一大篇呢),你自己參考相關資料。
逗號表示式最簡單的情形如下:
exp1, exp2;
c語言保證exp1在exp2之前求值,並且exp1求值的***保證在逗號之前生成。所以象下面這個逗號表示式:
int i = 1;
i++, (i == 2);
最後的值就是1,因為逗號表示式的前半部分i++的***(i自增1)在逗號之前已經生成,所以當執行到(i == 2)的時候,i的值已經是2了,所以i == 2成立,(i == 2)的值便作為整個逗號表示式的值。
但是,對函式原型,函式定義,函式呼叫,c語言裡面明確說明,引數列表裡面的逗號不是逗號操作符,只起到分隔作用,所以這裡的逗號不再是乙個順序點,那它前後的表示式的求值順序就是任意的,並且所有帶***的表示式的***都要等到下乙個順序點之後才是確定的,也就是說你只有等到下乙個順序點之後,你才能準確得依賴這些表示式產生的***。
所以,像這樣的函式呼叫
foo(i++, ++i);是得不到準確的結果的。因為這裡逗號不是逗號操作符,所以就算編譯器選擇的是從左到右的求值順序,由於c語言不再保證i++的***在逗號之前生成,算到++i的時候,都不確定i到底有沒有自增1,不確定性就在這裡產生了。再者,如果編譯器選擇的是從右到左求值,同樣產生不確定性,這樣一來,傳進函式foo的兩個引數的值就可能不同,那麼最後的結果當然也就不同了。
你這裡一樣,printf是乙個函式,
printf("%d,%d,%d\n",++i,--i,-i++);
是函式呼叫,括號內的所有逗號都不是逗號操作符,而只起到分隔引數的作用。所以++i,--i,-i++這三個表示式的求值順序是任意的,編譯器想怎麼算就怎麼算,不同的編譯器的「想法」可能相同可能不同,結果就可能一樣可能不一樣。這才是樓上的各位得到不同結果的真正原因!!!
樓主要好好參考順序點的定義和作用,並且牢記下面這條規則:
c語言裡面明確指出:在兩個順序點之間兩次改變同乙個變數的任何嘗試得到的結果都是不確定的!
你這裡int i=10;
printf("%d,%d,%d\n",++i,--i,-i++);
的兩個順序點分別是int i=10;的分號,和包圍printf的引數的括號,c語言只保證位於兩個順序點之間的表示式求值產生***在第二個順序點之前生成,但不保證兩個順序點之間所有表示式的求值順序。你這裡++i,--i,-i++三個表示式企圖在兩個順序點前乙個分號和()之間三次改變同乙個變數i的值,所以結果注定是不確定的。至於為什麼c語言要規定相鄰順序點之間的表示式以任意順序求值,是為了給編譯器更多的自由空間,讓底層運算操作能由編譯器排程安排從而使運算更有效地執行。
另外,站長團上有產品**,便宜***
7樓:小雲小冉
這裡首先說一句,你這種用法應該是不合法的,至少是很不可取的。因為像+、-、*、/這類算術運算子c語言並未規定運算元的求值順序,在不同的編譯器上,有可能先求做運算元,也有可能先求右運算元。所以建議不要採用這種不確定的式子。
你這裡是先求左運算元,也就是先求++n表示式的值,因為是字首自增,表示式(左運算元)值為6,此時n也變為6.然後求右運算元值,即表示式n++;的值,因為是字尾自增,所以表示式的值是6,因此第二運算元的值是6,因此結果是36.之後n變為7.
8樓:釗悟泥迎波
123456789main( )
9樓:匿名使用者
scanf輸入6[x=6], x>5成立, 緊接著無條件執行x++[x=7], 由於前面條件滿足, printf輸出7
scanf輸入4[x=4], x>5不成立, 緊接著無條件執行x++[x=5], 由於前面條件不滿足, printf輸出5, 執行x--[x=4]
因此輸入6時得到輸出7; 輸入4時得到輸出5
10樓:已存在這個名字
輸入6的時候,滿足if語句,x+1,輸出7,程式結束;
輸入4的時候,不滿足if語句,x+1,輸出5,x-1,程式結束。
11樓:傻仔青蛙
++在前面表示先進行變數自增,再執行算式,所以m=++i,先執行++i,i變為9,再賦值給m;
++在後面表示先進行算式,再執行變數自增,所以n=j++,先執行n=j,n被賦值為10,再j自增為11
12樓:匿名使用者
++前,表示先自加,後運算。
後++,表示先運算,後自加。
.所以,m=++i;先執行自加,即i=i+1;得i=9;
再運算,m=i;得m=9;
n=j++;先運算,即n=j;得n=10;
再自加,即j=j+1;得j=11;
.結果就是:
i=9,j=11,m=9,n=10.
13樓:匿名使用者
有乙個簡單的記憶方法,++在前,就是先自增,i在後,就是自增以後再給值;相反,i在前,就是先給出i的值,++在後,就是把值給出來以後再自增。
m=++i; i先自增,自增以後為9,然後把9給mn=j++; 先把j的值10給n,然後再自增,j變成了11所以得結果。
如果滿意請採納
14樓:看灰過來了
把自增或者自減表示式作為函式引數,本身就應該被避免的,因為不同的編譯系統,在計算的時候,方法並不統一。例如;
i=1;
c=fun(i,++i);
當從左向右計算,那就是c=fun(1,2);
要是從右向左計算,就是c=fun(2,2);
這類問題不必深究,而是應該在呼叫函式之前,將實參的值給它確定了,然後再作為實參去呼叫函式
15樓:唐博
第一段**:
++i是先增加i的值,然後使用。
p=f(i,++i); 是先執行++i,後進行函式呼叫。因為執行了++i以後,i的值已經變成了3,
所以相當於p=f(3,3);
你可以在函式f裡面把a和b的值列印出來,你會發現a和b都是3.
第二段**:
i++是先使用i的值,然後把i的值加1.
所以相當於先執行p=f(2,2);
執行之後,把i的值變成3.答案應該是0.
我懷疑你們老師的課件寫錯了,建議你去問問他。
16樓:windy笨笨狗
主要自增自減問題,方面你記憶,給個方法
x++表示式的值從左到右看x的位置,此時x在++左,還沒有++,故 x++表示式的值就是x值
相反++x,x在++右邊,表示式的值即x+1的值但是不管哪種,只要執行完了,x的值就+1
x--,--x一樣
故: 6時: if(6>5) ,輸出 74時: if(4>5)不滿足, 執行x--,但是此時x已經執行了一遍++,故x在--前為5
x--表示式的值 為5
希望對你有用,望採納
17樓:匿名使用者
m=++i; // i++;m=i
n=j++ ; // n=j,j++
18樓:錢柯偉有錢
這個問題以前我也不懂,現在會了。不懂確實很煩人。首先,i=8,m=++i,前置是先+1,再取值,那麼m=9,而此時的i就是+1之後的運算結果,i=9.
j=10,n=j++.++在後,就是先取值,再+1;那麼n先取值就是10.j的值就是j+1後的值,j=11.
c語言裡自加++和自減——放變數前和變數後有什麼不同作用啊,分別怎麼計算的?
19樓:匿名使用者
運算子在前,表示運算在前取值在後;運算子在後,表示運算在後取值在前c語言是過程式程式語言。不同於「純」函式式程式語言,c語言的表示式可以改變變數的值或外部狀態,這被稱為表示式的「***」(side effect)。++i 就是含有***的表示式,在對 ++i / --i 這樣的字首運算子(prefix increment and decrement operators)求值的過程中,按定義發生了以下兩步
改變變數 i 的值
確定運算結果是變數 i 改變後的值
而在對 i++ / i-- 這樣的字尾運算子(postfix increment and decrement operators)求值的過程中,則是以下兩步
確定運算結果是變數 i 的值(此時 i 的值還沒有改變)改變變數 i 的值
c語言關於自增自減的問題,c語言的自增自減問題
乙個是先運算後加減 就輸出了x是10 但是再次輸出就是9了 後乙個是先加減後輸出 所以是9 再輸出還是9 前 表示先自減,再使用變數 n y等價於 y y 1 n y 這兩步操作 後 表示先用變數,再進行自減 n x 等價於 n x x x 1 這兩步操作 因此,題目答案為 10 9 d正確 舉個例...
哪位高手能我解釋一下,關於C語言的自加和自減,越詳細越好
自增 自減類同,以下只以 自增 為例 運算需要留意的乙個主要關鍵點即是前自增 i 和後自增 i 的區別,大致說來,二者的區別如下 1 前自增是 先完成自增,後參與表示式運算 的 後自增卻恰恰相反,於是會產生如下區別 int i 0 printf d i 輸出 0 printf d i 輸出 1,此句...
c語言中什麼是數的有效數字,C語言中什麼是乙個數的有效數字?
樓上誤解 樓主問的是c語言 不是數學 這要看你的機器型別和變數型別了 如果定義的是int型 那1234是有 版效數字 權 後面小數都是無效的 如果定義的是float型 那在限定位元組長度內都是有效數字不同機器型別也不一樣 int型有2個位元組 也有4個位元組的 在c語言中,bai乙個數的有效數du字...