程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> 關於C語言 >> C語言整型數據(整數)使用基礎技巧

C語言整型數據(整數)使用基礎技巧

編輯:關於C語言
 

整型數據即整數。

整型數據的分類

整型數據的一般分類如下:

  • 基本型:類型說明符為int,在內存中占2個字節。

  • 短整型:類型說明符為short int或short。所占字節和取值范圍均與基本型相同。

  • 長整型:類型說明符為long int或long,在內存中占4個字節。

  • 無符號型:類型說明符為unsigned。


無符號型又可與上述三種類型匹配而構成:

  • 無符號基本型:類型說明符為unsigned int或unsigned。

  • 無符號短整型:類型說明符為unsigned short。

  • 無符號長整型:類型說明符為unsigned long。


下表列出了C語言中各類整型數據所分配的內存字節數及數的表示范圍。

avfd.png

整型數據在內存中的存放形式

如果定義了一個整型變量i:

int i;
i=10;

整型變量


數值是以補碼表示的:

  • 正數的補碼和原碼相同;

  • 負數的補碼:將該數的絕對值的二進制形式按位取反再加1。


例如:求-10的補碼:


由此可知,左面的第一位是表示符號的。
各種無符號整型數據所占的內存空間字節數與相應的有符號類型量相同。但由於省去了符號位,故不能表示負數。


以13為例:

fe.png

整型數據的表示方法

上面講到的整數,都是十進制。在C語言中,常用的還有八進制和十六進制。下面集中講解一下:
1) 十進制數
十進制數沒有前綴。其數碼為0~9。
以下是合法的十進制數:237、-568、65535、1627;
以下是不合法的十進制數:023 (不能有前導0)、23D (含有非十進制數碼)。
在程序中是根據前綴來區分各種進制數的。因此在書寫時不要把前綴弄錯造成結果不正確。
2) 八進制數
八進制數必須以0開頭,即以0作為八進制數的前綴。數碼取值為0~7。八進制數通常是無符號數。
以下是合法的八進制數:015(十進制為13)、0101(十進制為65)、0177777(十進制為65535);
以下是不合法的八進制數:256(無前綴0)、03A2(包含了非八進制數碼)、-0127(出現了負號)。
3) 十六進制數
十六進制數的前綴為0X或0x。其數碼取值為0~9,A~F或a~f。
以下是合法的十六進制數:0X2A(十進制為42)、0XA0 (十進制為160)、0XFFFF (十進制為65535);
以下是不合法的十六進制數:5A (無前綴0X)、0X3H (含有非十六進制數碼)。
4) 整數的後綴
可以用後綴“L”或“l”來表示長整型數。例如:

  • 十進制長整型數:158L (十進制為158)、358000L (十進制為358000);

  • 八進制長整型數:012L (十進制為10)、077L (十進制為63)、0200000L (十進制為65536);

  • 十六進制長整型數:0X15L (十進制為21)、0XA5L (十進制為165)、0X10000L (十進制為65536)。


長整型數158L和基本整型數158 在數值上並無區別。但對158L,因為是長整型數,C編譯系統將為它分配4個字節存儲空間。而對158,因為是基本整型,只分配2 個字節的存儲空間。因此在運算和輸出格式上要予以注意,避免出錯。
無符號數也可用後綴表示,整型數的無符號數的後綴為“U”或“u”。例如:358u、0x38Au、235Lu均為無符號數。
前綴,後綴可同時使用以表示各種類型的數。如0XA5Lu表示十六進制無符號長整型數A5,其十進制為165。
幾個整型變量的定義:

int a,b,c;  // a,b,c為整型變量
long x,y;  // x,y為長整型變量
unsigned p,q;  // p,q為無符號整型變量


【例3-2】整型變量的定義與使用。

#include <stdio.h>
int main(){
    int a,b,c,d;
    unsigned u;
    a=12;b=-24;u=10;
    c=a+u;d=b+u;
    printf("a+u=%d,b+u=%d\n",c,d);
    return 0;
}

整型數據的溢出

【例3-3】整型數據的溢出。

#include <stdio.h>
int main(){
    int a,b;
    a=32767;
    b=a+1;
    printf("%d,%d\n",a,b);
    return 0;
}


注意:以上結果是在TC2.0下得出的;在VC6.0下,輸出值是 32767, 32768。因為 int 類型在 TC2.0下默認是short int,占2個字節,在VC6.0下默認是 long int,占4個字節,32768不會導致溢出。將 a = 32767 改成 a = 2147483647 後即可看到溢出。
【例3-4】不同類型變量賦值

#include <stdio.h>
int main(){
    long x,y;
    int a,b,c,d;
    x=5;
    y=6;
    a=7;
    b=8;
    c=x+a;
    d=y+b;
    printf("c=x+a=%d,d=y+b=%d\n",c,d);
    return 0;
}

從程序中可以看到:x、y是長整型變量,a、b是基本整型變量。它們之間允許進行運算,運算結果為長整型。但c、d被定義為基本整型,因此最後結果為基本整型。本例說明,不同類型的量可以參與運算並相互賦值。其中的類型轉換是由編譯系統自動完成的。有關類型轉換的規則將在後面介紹。

 
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved