激情欧美日韩一区二区,浪货撅高贱屁股求主人调教视频,精品无码成人片一区二区98,国产高清av在线播放,色翁荡息又大又硬又粗视频

計算機二級C語(yǔ)言數據類(lèi)型

時(shí)間:2024-08-28 06:41:40 計算機等級 我要投稿

計算機二級C語(yǔ)言數據類(lèi)型

  C語(yǔ)言提供多種運算符和表達式值的方法,對問(wèn)題的表達可通過(guò)多種途徑獲得,其程序設計更主動(dòng)、靈活。下面是小編整理的關(guān)于計算機二級C語(yǔ)言數據類(lèi)型,希望大家認真閱讀!

  字符串常量

  字符串常量是由一對雙引號括起的字符序列。例如: "CHINA" ,"C program:" , "$12.5" 等都是合法的字符串常量。字符串常量和字符常量是不同的量。它們之間主要有以下區別:

  1.字符常量由單引號括起來(lái),字符串常量由雙引號括起來(lái)。

  2.字符常量只能是單個(gè)字符,字符串常量則可以含一個(gè)或多個(gè)字符。

  3.可以把一個(gè)字符常量賦予一個(gè)字符變量,但不能把一個(gè)字符串常量賦予一個(gè)字符變量。在C語(yǔ)言中沒(méi)有相應的字符串變量。 來(lái)源:www.examda.com

  這是與BASIC 語(yǔ)言不同的。但是可以用一個(gè)字符數組來(lái)存放一個(gè)字符串常量。在數組一章內予以介紹。

  4.字符常量占一個(gè)字節的內存空間。字符串常量占的內存字節數等于字符串中字節數加1。增加的一個(gè)字節中存放字符"\0"(ASCII碼為0)。這是字符串結束的標志。例如,字符串 "C program"在內存中所占的字節為:C program\0。字符常量’a’和字符串常量"a"雖然都只有一個(gè)字符,但在內存中的情況是不同的。

  ’a’在內存中占一個(gè)字節,可表示為:a

  "a"在內存中占二個(gè)字節,可表示為:a\0符號常量

  符號常量

  在C語(yǔ)言中,可以用一個(gè)標識符來(lái)表示一個(gè)常量,稱(chēng)之為符號常量。符號常量在使用之前必須先定義,其一般形式為:

  #define 標識符 常量

  其中#define也是一條預處理命令(預處理命令都?quot;#"開(kāi)頭),稱(chēng)為宏定義命令(在第九章預處理程序中將進(jìn)一步介紹),其功能是把該標識符定義為其后的常量值。一經(jīng)定義,以后在程序中所有出現該標識符的地方均代之以該常量值。習慣上符號常量的標識符用大寫(xiě)字母,變量標識符用小寫(xiě)字母,以示區別。

  #define PI 3.14159

  void main()

  {

  float s,r;

  r=5;

  s=PI*r*r;

  printf("s=%f\n",s);

  }

  由宏定義命令定義PI 為3.14159 s,r定義為實(shí)數 5->r PI*r*r->s

  顯示程序結果 float s,r; r=5; s=PI*r*r; 本程序在主函數之前由宏定義命令定義PI 為3.14159,在程序中即以該值代替PI 。s=PI*r*r等效于s=3.14159*r*r。應該注意的是,符號常量不是變量,它所代表的值在整個(gè)作用域內不能再改變。也就是說(shuō),在程序中,不能再用賦值語(yǔ)句對它重新賦值。 來(lái)源:www.examda.com

  變量的初值和類(lèi)型轉換

  變量賦初值

  在程序中常常需要對變量賦初值,以便使用變量。語(yǔ)言程序中可有多種方法,在定義時(shí)賦以初值的方法,這種方法稱(chēng)為初始化。在變量說(shuō)明中賦初值的一般形式為:

  類(lèi)型說(shuō)明符 變量1= 值1,變量2= 值2,……; 例如:

  int a=b=c=5;

  float x=3.2,y=3f,z=0.75;

  char ch1=’K’,ch2=’P’;

  應注意,在說(shuō)明中不允許連續賦值,如a=b=c=5是不合法的。

  void main()

  {

  int a=3,b,c=5;

  b=a+c;

  printf("a=%d,b=%d,c=%d\n",a,b,c);

  }

  a<---3,b<--0,c<---5

  b<--a+c

  顯示程序運行結果

  變量類(lèi)型的轉換 來(lái)源:www.examda.com

  變量的數據類(lèi)型是可以轉換的。轉換的方法有兩種, 一種是自動(dòng)轉換,一種是強制轉換。

  自動(dòng)轉換

  自動(dòng)轉換發(fā)生在不同數據類(lèi)型的量混合運算時(shí),由編譯系統自動(dòng)完成。自動(dòng)轉換遵循以下規則:

  1.若參與運算量的類(lèi)型不同,則先轉換成同一類(lèi)型,然后進(jìn)行運算。

  2.轉換按數據長(cháng)度增加的方向進(jìn)行,以保證精度不降低。如int型和long型運算時(shí),先把int量轉成long型后再進(jìn)行運算。

  3.所有的浮點(diǎn)運算都是以雙精度進(jìn)行的,即使僅含float單精度量運算的表達式,也要先轉換成double型,再作運算。

  4.char型和short型參與運算時(shí),必須先轉換成int型。

  5.在賦值運算中,賦值號兩邊量的數據類(lèi)型不同時(shí), 賦值號右邊量的類(lèi)型將轉換為左邊量的類(lèi)型。 如果右邊量的數據類(lèi)型長(cháng)度左邊長(cháng)時(shí),將丟失一部分數據,這樣會(huì )降低精度, 丟失的部分按四舍五入向前舍入。圖2——1表示了類(lèi)型自動(dòng)轉換的規則。

  void main()

  {

  float PI=3.14159;

  int s,r=5;

  s=r*r*PI;

  printf("s=%d\n",s);

  }

  PI<--3.14159

  s<--0,r<--5

  s<--r*r*PI

  顯示程序運行結果

  float PI=3.14159;

  int s,r=5;

  s=r*r*PI;

  本例程序中,PI為實(shí)型;s,r為整型。在執行s=r*r*PI語(yǔ)句時(shí),r和PI都轉換成double型計算,結果也為double型。但由于s為整型,故賦值結果仍為整型,舍去了小數部分。

  強制類(lèi)型轉換

  強制類(lèi)型轉換是通過(guò)類(lèi)型轉換運算來(lái)實(shí)現的。其一般形式為: (類(lèi)型說(shuō)明符) (表達式) 其功能是把表達式的運算結果強制轉換成類(lèi)型說(shuō)明符所表示的類(lèi)型。例如: (float) a 把a轉換為實(shí)型(int)(x+y) 把x+y的結果轉換為整型在使用強制轉換時(shí)應注意以下問(wèn)題:

  1.類(lèi)型說(shuō)明符和表達式都必須加括號(單個(gè)變量可以不加括號),如把(int)(x+y)寫(xiě)成(int)x+y則成了把x轉換成int型之后再與y相加了。

  2.無(wú)論是強制轉換或是自動(dòng)轉換,都只是為了本次運算的需要而對變量的數據長(cháng)度進(jìn)行的臨時(shí)性轉換,而不改變數據說(shuō)明時(shí)對該變量定義的類(lèi)型。

  main()

  {

  float f=5.75;

  printf("(int)f=%d,f=%f\n",(int)f,f);

  }

  f<--5.75

  將float f強制轉換成int f float f=5.75;printf("(int)f=%d,f=%f\n",(int)f,f); 本例表明,f雖強制轉為int型,但只在運算中起作用, 是臨時(shí)的,而f本身的類(lèi)型并不改變。因此,(int)f的值為 5(刪去了小數)而f的值仍為5.75。

  基本運算符和表達式

  運算符的種類(lèi)、優(yōu)先級和結合性

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

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

  運算符的種類(lèi)C語(yǔ)言的運算符可分為以下幾類(lèi):

  1.算術(shù)運算符

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

  2.關(guān)系運算符

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

  3.邏輯運算符

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

  4.位操作運算符

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

  5.賦值運算符

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

  6.條件運算符

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

  7.逗號運算符

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

  8.指針運算符

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

  9.求字節數運算符

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

  10.特殊運算符

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

  優(yōu)先級和結合性

  C語(yǔ)言中,運算符的運算優(yōu)先級共分為15級。1級最高,15級最低。在表達式中,優(yōu)先級較高的先于優(yōu)先級較低的進(jìn)行運算。 而在一個(gè)運算量?jì)蓚鹊倪\算符優(yōu)先級相同時(shí), 則按運算符的結合性所規定的結合方向處理。 C語(yǔ)言中各運算符的結合性分為兩種,即左結合性(自左至右)和右結合性(自右至左)。例如算術(shù)運算符的結合性是自左至右,即先左后右。如有表達式x-y+z則y應先與“-”號結合, 執行x-y運算,然后再執行+z的運算。這種自左至右的結合方向就稱(chēng)為“左結合性”。而自右至左的結合方向稱(chēng)為“右結合性”。 最典型的右結合性運算符是賦值運算符。如x=y=z,由于“=”的右結合性,應先執行y=z再執行x=(y=z)運算。 C語(yǔ)言運算符中有不少為右結合性,應注意區別,以避免理解錯誤。 來(lái)源:www.examda.com

  算術(shù)運算符和算術(shù)表達式基本的算術(shù)運算符

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

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

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

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

  void main(){

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

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

  }

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

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

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

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

  void main(){

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

  }

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

  自增1,自減1運算符

  自增1運算符記為“++”,其功能是使變量的值自增1。自減1運算符記為“--”,其功能是使變量值自減1。自增1,自減1運算符均為單目運算,都具有右結合性?捎幸韵聨追N形式: ++i i自增1后再參與其它運算。--i i自減1后再參與其它運算。

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

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

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

  void main(){

  int i=8;

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

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

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

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

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

  printf("%d\n",-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\n",++i);

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

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

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

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

  printf("%d\n",-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);

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

  算術(shù)表達式

  是由算術(shù)運算符和括號連接起來(lái)的式子, 以下是算術(shù)表達式的例子:

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

  賦值運算符和賦值表達式

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

  x=a+b

  w=sin(a)+sin(b)

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

  a=b=c=5

  可理解為

  a=(b=(c=5))

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

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

【計算機二級C語(yǔ)言數據類(lèi)型】相關(guān)文章:

計算機二級C語(yǔ)言數據類(lèi)型及其運算03-06

計算機二級c語(yǔ)言題庫及答案03-28

計算機二級C語(yǔ)言考點(diǎn)盤(pán)點(diǎn)03-09

2016計算機二級c語(yǔ)言習題及答案03-08

計算機二級考試c語(yǔ)言過(guò)關(guān)經(jīng)驗03-21

計算機二級C語(yǔ)言復習資料03-02

計算機二級C語(yǔ)言題庫2016最新03-29

計算機二級《C語(yǔ)言》模擬試題及答案03-29

計算機二級C語(yǔ)言真題及答案09-26

激情欧美日韩一区二区,浪货撅高贱屁股求主人调教视频,精品无码成人片一区二区98,国产高清av在线播放,色翁荡息又大又硬又粗视频