<address id="ousso"></address>
<form id="ousso"><track id="ousso"><big id="ousso"></big></track></form>
  1. C語言

    C語言的運算符和表達式有哪些

    時間:2025-04-02 17:08:45 C語言 我要投稿
    • 相關推薦

    C語言的運算符和表達式有哪些

      C語言的應用范圍廣泛,具備很強的數據處理能力,不僅僅是在軟件開發上,而且各類科研都需要用到C語言,適于編寫系統軟件,三維,二維圖形和動畫,具體應用比如單片機以及嵌入式系統開發。以下是小編為大家搜索整理的C語言的運算符和表達式有哪些,希望能給大家帶來幫助!

      運算符的種類、優先級和結合性

      C語言中運算符和表達式數量之多, 在高級語言中是少見的。正是豐富的運算符和表達式使C語言功能十分完善。 這也是C語言的主要特點之一。

      C語言的運算符不僅具有不同的優先級, 而且還有一個特點,就是它的結合性。在表達式中, 各運算量參與運算的先后順序不僅要遵守運算符優先級別的規定,還要受運算符結合性的制約, 以便確定是自左向右進行運算還是自右向左進行運算。 這種結合性是其它高級語言的運算符所沒有的,因此也增加了C語言的復雜性。

      運算符的種類C語言的運算符可分為以下幾類:

      1.算術運算符

      用于各類數值運算。包括加(+)、減(-)、乘(*)、除(/)、求余(或稱模運算,%)、自增(++)、自減(--)共七種。

      2.關系運算符

      用于比較運算。包括大于(>)、小于(<)、等于(==)、>=)、小于等于(<=)和不等于(!=)六種。

      3.邏輯運算符

      用于邏輯運算。包括與(&&)、或(||)、非(!)三種。

      4.位操作運算符

      參與運算的量,按二進制位進行運算。包括位與(&)、位或(|)、位非(~)、位異或(^)、左移(<<)、右移(>>)六種。

      5.賦值運算符

      用于賦值運算,分為簡單賦值(=)、復合算術賦值(+=,-=,*=,/=,%=)和復合位運算賦值(&=,|=,^=,>>=,<<=)三類共十一種。

      6.條件運算符

      這是一個三目運算符,用于條件求值(?:)。

      7.逗號運算符

      用于把若干表達式組合成一個表達式(,)。

      8.指針運算符

      用于取內容(*)和取地址(&)二種運算。

      9.求字節數運算符

      用于計算數據類型所占的字節數(sizeof)。

      10.特殊運算符

      有括號(),下標[],成員(→,.)等幾種。

      優先級和結合性

      C語言中,運算符的運算優先級共分為15級。1級最高,15級最低。在表達式中,優先級較高的先于優先級較低的進行運算。 而在一個運算量兩側的運算符優先級相同時, 則按運算符的結合性所規定的結合方向處理。 C語言中各運算符的結合性分為兩種,即左結合性(自左至右)和右結合性(自右至左)。例如算術運算符的結合性是自左至右,即先左后右。如有表達式x-y+z則y應先與“-”號結合, 執行x-y運算,然后再執行+z的運算。這種自左至右的結合方向就稱為“左結合性”。而自右至左的結合方向稱為“右結合性”。 最典型的右結合性運算符是賦值運算符。如x=y=z,由于“=”的右結合性,應先執行y=z再執行x=(y=z)運算。 C語言運算符中有不少為右結合性,應注意區別,以避免理解錯誤。

      算術運算符和算術表達式基本的算術運算符

      1.加法運算符“+”加法運算符為雙目運算符,即應有兩個量參與加法運算。如a+b,4+8等。具有右結合性。

      2.減法運算符“-”減法運算符為雙目運算符。但“-”也可作負值運算符,此時為單目運算,如-x,-5等具有左結合性。

      3.乘法運算符“*”雙目運算,具有左結合性。

      4.除法運算符“/”雙目運算具有左結合性。參與運算量均為整型時, 結果也為整型,舍去小數。如果運算量中有一個是實型,則結果為雙精度實型。

      void main(){

      printf(" %d,%d ",20/7,-20/7);

      printf("%f,%f ",20.0/7,-20.0/7);

      }

      雙目運算具有左結合性。參與運算量均為整型時, 結果也為整型,舍去小數。如果運算量中有一個是實型,則結果為雙精度實型。 printf(" %d,%d ",20/7,-20/7);

      printf("%f,%f ",20.0/7,-20.0/7);

      本例中,20/7,-20/7的結果均為整型,小數全部舍去。而20.0/7和-20.0/7由于有實數參與運算,因此結果也為實型。

      5.求余運算符(模運算符)“%”雙目運算,具有左結合性。要求參與運算的量均為整型。 求余運算的結果等于兩數相除后的余數。

      void main(){

      printf("%d ",100%3);

      }

      雙目運算,具有左結合性。求余運算符% 要求參與運算的量均為整型。本例輸出100除以3所得的余數1。

      自增1,自減1運算符

      自增1運算符記為“++”,其功能是使變量的值自增1。自減1運算符記為“--”,其功能是使變量值自減1。自增1,自減1運算符均為單目運算,都具有右結合性。可有以下幾種形式: ++i i自增1后再參與其它運算。--i i自減1后再參與其它運算。

      i++  i參與運算后,i的值再自增1。

      i--  i參與運算后,i的值再自減1。

      在理解和使用上容易出錯的是i++和i--。 特別是當它們出在較復雜的表達式或語句中時,常常難于弄清,因此應仔細分析。

      void main(){

      int i=8;

      printf("%d ",++i);

      printf("%d ",--i);

      printf("%d ",i++);

      printf("%d ",i--);

      printf("%d ",-i++);

      printf("%d ",-i--);

      } i<--8

      i<--i+1

      i<--i-1

      i<--i+1

      i<--i-1

      i<--i+1

      i<--i-1 int i=8;

      printf("%d ",++i);

      printf("%d ",--i);

      printf("%d ",i++);

      printf("%d ",i--);

      printf("%d ",-i++);

      printf("%d ",-i--);

      i的初值為8

      第2行i加1后輸出故為9;

      第3行減1后輸出故為8;

      第4行輸出i為8之后再加1(為9);

      第5行輸出i為9之后再減1(為8) ;

      第6行輸出-8之后再加1(為9);

      第7行輸出-9之后再減1(為8)

      void main(){

      int i=5,j=5,p,q;

      p=(i++)+(i++)+(i++);

      q=(++j)+(++j)+(++j);

      printf("%d,%d,%d,%d",p,q,i,j);

      }

      i<--5,j<--5,p<--0,q<--0

      i+i+i--->p,i+1-->i,i+1-->i,i+1-->i

      j+1->j,j+1->j,j+1->j,j+j+j->q int i=5,j=5,p,q;

      p=(i++)+(i++)+(i++);

      q=(++j)+(++j)+(++j);

      這個程序中,對P=(i++)+(i++)+(i++)應理解為三個i相加,故P值為15。然后i再自增1三次相當于加3故i的最后值為8。而對于q 的值則不然,q=(++j)+(++j)+(++j)應理解為q先自增1,再參與運算,由于q自增1三次后值為8,三個8相加的和為24,j的最后值仍為8。算術表達式表達式是由常量、變量、函數和運算符組合起來的式子。 一個表達式有一個值及其類型, 它們等于計算表達式所得結果的值和類型。表達式求值按運算符的優先級和結合性規定的順序進行。 單個的常量、變量、函數可以看作是表達式的特例。

      算術表達式

      是由算術運算符和括號連接起來的式子, 以下是算術表達式的例子:

      a+b  (a*2)/c (x+r)*8-(a+b)/7  ++i sin(x)+sin(y)  (++i)-(j++)+(k--)

      賦值運算符和賦值表達式

      簡單賦值運算符和表達式,簡單賦值運算符記為“=”。由“= ”連接的式子稱為賦值表達式。其一般形式為: 變量=表達式 例如:

      x=a+b

      w=sin(a)+sin(b)

      y=i+++--j 賦值表達式的功能是計算表達式的值再賦予左邊的變量。賦值運算符具有右結合性。因此

      a=b=c=5

      可理解為

      a=(b=(c=5))

      在其它高級語言中,賦值構成了一個語句,稱為賦值語句。 而在C中,把“=”定義為運算符,從而組成賦值表達式。 凡是表達式可以出現的地方均可出現賦值表達式。例如,式子x=(a=5)+(b=8)是合法的。它的意義是把5賦予a,8賦予b,再把a,b相加,和賦予x ,故x應等于13。

      在C語言中也可以組成賦值語句,按照C語言規定, 任何表達式在其未尾加上分號就構成為語句。因此如x=8;a=b=c=5;都是賦值語句,在前面各例中我們已大量使用過了。

      如果賦值運算符兩邊的數據類型不相同, 系統將自動進行類型轉換,即把賦值號右邊的類型換成左邊的類型。具體規定如下:

      1.實型賦予整型,舍去小數部分。前面的例2.9已經說明了這種情況。

      2.整型賦予實型,數值不變,但將以浮點形式存放, 即增加小數部分(小數部分的值為0)。

      3.字符型賦予整型,由于字符型為一個字節, 而整型為二個字節,故將字符的ASCII碼值放到整型量的低八位中,高八位為0。

      4.整型賦予字符型,只把低八位賦予字符量。

      void main(){

      int a,b=322;

      float x,y=8.88;

      char c1='k',c2;

      a=y;

      x=b;

      a=c1;

      c2=b;

      printf("%d,%f,%d,%c",a,x,a,c2);

      }

      int a,b=322;

      float x,y=8.88;

      char c1='k',c2;

      printf("%d,%f,%d,%c",a=y,x=b,a=c1,c2=b);

      本例表明了上述賦值運算中類型轉換的規則。a為整型,賦予實型量y值8?88后只取整數8。x為實型,賦予整型量b值322, 后增加了小數部分。字符型量c1賦予a變為整型,整型量b賦予c2 后取其低八位成為字符型(b的低八位為01000010,即十進制66,按ASCII碼對應于字符B)。

      復合賦值符及表達式

      在賦值符“=”之前加上其它二目運算符可構成復合賦值符。如

      +=,-=,*=,/=,%=,<<=,>>=,&=,^=,|=。 構成復合賦值表達式的一般形式為: 變量 雙目運算符=表達式 它等效于 變量=變量 運算符 表達式 例如: a+=5 等價于a=a+5  x*=y+7 等價于x=x*(y+7)  r%=p 等價于r=r%p 復合賦值符這種寫法,對初學者可能不習慣, 但十分有利于編譯處理,能提高編譯效率并產生質量較高的目標代碼。逗號運算符和逗號表達式在

      逗號運算符

      C語言中逗號“,”也是一種運算符,稱為逗號運算符。 其功能是把兩個表達式連接起來組成一個表達式, 稱為逗號表達式。

      其一般形式為: 表達式1,表達式2 其求值過程是分別求兩個表達式的值,并以表達式2的值作為整個逗號表達式的值。

      void main(){

      int a=2,b=4,c=6,x,y;

      y=(x=a+b),(b+c);

      printf("y=%d,x=%d",y,x);

      }

      a<--2,b<--4,c<--6,x<--0,y<--0

      x<--a+b,y<---b+c

      本例中,y等于整個逗號表達式的值,也就是表達式2的值,x是第一個表達式的值。對于逗號表達式還要說明兩點:

      1.逗號表達式一般形式中的表達式1和表達式2 也可以又是逗號表達式。例如: 表達式1,(表達式2,表達式3) 形成了嵌套情形。因此可以把逗號表達式擴展為以下形式: 表達式1,表達式2,…表達式n 整個逗號表達式的值等于表達式n的值。

      2.程序中使用逗號表達式,通常是要分別求逗號表達式內各表達式的值,并不一定要求整個逗號表達式的值。

      3.并不是在所有出現逗號的地方都組成逗號表達式,如在變量說明中,函數參數表中逗號只是用作各變量之間的間隔符。

      C語言變量理解

      一、變量的概念

      程序設計就是讓計算機按照一定的指令來進行工作,可以說數據的處理是程序設計的主要任務。那么數據是怎么加入到計算機的內存中呢?計算機最初的功能就是能夠存儲數據并處理數據的機器。那么數據是怎么加入到計算機的內存中呢?在學習程序設計之前,很多學生對計算機的硬件設施都大概已經很熟悉了。計算機的硬件設施中有一個區域是用來存儲數據的,計算機在工作的過程中會頻繁的從這個區域讀入和讀出數據。要想讓計算機按照某些指令(程序)自動工作,首先必須把數據存儲到計算機的存儲空間中。在某種計算機語言中實現這種數據存儲功能的就是變量。變量就是計算機內存中的某一個存儲單元。

      二、變量的定義

      C語言中變量在使用之前必須先對其進行定義,變量的定義的一般形式如下:【存儲類別】數據類型變量名;其中存儲類別是可以省略的。

      1、存儲類別計算機的內存一般分為三個部分:

      1)程序區;

      2)靜態存儲區;

      3)動態存儲區;為了高效的發揮計算機的功能,不同類型的變量存放在不同的內存區域。變量的存儲類別決定了變量中的數據在計算機內存中的存儲位置。C語言中局部變量存放在動態存儲區,全局變量或者靜態變量存放在靜態存儲區。

      2、數據類型在用程序處理問題之前,首先必須確定用何種方式描述問題中所涉及到的數據。這個問題在C語言中是由數據類型來決定的。變量的本質表現為在計算機中的存在時間和存儲空間。變量的數據類型是用來決定變量在計算機中占用內存空間的大小。比如:整型數據在TC編譯系統中占用兩個字節的存儲空間。C語言變量的類型不僅確定了數據在計算機內存中的存儲區域的大小,同時確定了該數據能夠參與的各種運算。任何一個C語言的變量必須有確定的數據類型,不管這個變量如何變化,變量的值都必須符合該變量數據類型的規定。

      3、變量的名字通過以上介紹我們知道C語言中的變量就是計算機的某個存儲單元,假設你給某個變量賦予了一個數值,對變量的處理其實就是對這個數據的處理。那么計算機是如何快速準確的找到這個數據呢?計算機的內存是以字節為單位進行劃分的。每個存儲單元都有自己的地址編號,就向賓館中房間的房間號一樣。計算機就是通過地址來準確的確定數據的存儲位置。但是對于程序員特別是非專業計算機人士,如果用計算機內存地址記錄數據是非常難操作的。

      為了更好的掌控變量,C語言規定可以給每個變量其一個容易識別的名字。這個名字的命名規則遵循C語言的標識符命名規則。C語言的變量名的命名在遵循C語言標識符規則的前提下,原則上可以是任意長度字符的組合。但是目前很多的C語言編譯系統只能識別前31個字符,如果兩個變量的前31個字符相同,則編譯系統會認為這兩個變量時同一個變量。為了避免這種混淆的出現最好避免使用多余31個字符的變量名。變量的理解變量就是計算機中的某個存儲單元。定義某個變量本質上就是向計算機申請一些存儲區域。這個存儲區域的大小由變量的數據類型決定,這個存儲區域的位置有變量的存儲類類別決定。給變量賦予某個數值,其實就是向該變量對應的存儲單元讀入數據,對變量的處理就是對這個存儲單元中的數據的處理。并且這個存儲單元中的數據在程序的運行期間是可以發生變化的。

      C語言基本算法

      1.交換(兩量交換借助第三者)

      例1、任意讀入兩個整數,將二者的值交換后輸出。

      main()

      {int a,b,t;

      scanf("%d%d",&a,&b);

      printf("%d,%d ",a,b);

      t=a; a=b; b=t;

      printf("%d,%d ",a,b);}

      【解析】程序中加粗部分為算法的核心,如同交換兩個杯子里的飲料,必須借助第三個空杯子。

      假設輸入的值分別為3、7,則第一行輸出為3,7;第二行輸出為7,3。

      其中t為中間變量,起到“空杯子”的作用。

      注意:三句賦值語句賦值號左右的各量之間的關系!

      【應用】

      例2、任意讀入三個整數,然后按從小到大的順序輸出。

      main()

      {int a,b,c,t;

      scanf("%d%d%d",&a,&b,&c);

      if(a>b){ t=a; a=b; b=t; }

      if(a>c){ t=a; a=c; c=t; }

      if(b>c) { t=b; b=c; c=t; }

      printf("%d,%d,%d ",a,b,c);}

      2.累加

      累加算法的要領是形如“s=s+A”的累加式,此式必須出現在循環中才能被反復執行,從而實現累加功能。“A”通常是有規律變化的表達式,s在進入循環前必須獲得合適的初值,通常為0。

      例1、求1+2+3+……+100的和。

      main()

      {int i,s;

      s=0; i=1;

      while(i<=100)

      {s=s+i;

      i=i+1;

      }

      printf("1+2+3+...+100=%d ",s);}

      【解析】程序中加粗部分為累加式的典型形式,賦值號左右都出現的變量稱為累加器,其中“i = i + 1”為特殊的累加式,每次累加的值為1,這樣的累加器又稱為計數器。

      3.累乘

      累乘算法的要領是形如“s=s*A”的累乘式,此式必須出現在循環中才能被反復執行,從而實現累乘功能。“A”通常是有規律變化的表達式,s在進入循環前必須獲得合適的初值,通常為1。

      例1、求10!

      [分析]10!=1×2×3×……×10

      main()

      {int i; long c;

      c=1; i=1;

      while(i<=10)

      {c=c*i;

      i=i+1;

      }

      printf("1*2*3*...*10=%ld ",c);}

    【C語言的運算符和表達式有哪些】相關文章:

    C語言的基本運算符和表達式08-10

    C語言算術運算符和算術表達式08-19

    C語言賦值運算符與賦值表達式07-23

    C語言邏輯運算符有哪些08-06

    Java的運算符和表達式10-08

    C語言輔導:C語言運算符表06-17

    C語言關系運算符08-04

    C語言賦值運算符11-06

    c語言算術運算符07-23

    <address id="ousso"></address>
    <form id="ousso"><track id="ousso"><big id="ousso"></big></track></form>
    1. 日日做夜狠狠爱欧美黑人