1. 程式人生 > >關於C語言的型別轉換問題

關於C語言的型別轉換問題

#include<stdio.h>
int main()

{


    char a = 10;
    printf("%d\n",~a);

    unsigned char c = 10;
    printf("%d\n",~c);

    char b = 128;
    printf("%d\n",b);

    return 0;
}

執行結果:

-11
-11
-128
Press any key to continue

解題:
有符號char 的取值範圍: -128 – 到– +127
10 原碼 與 補碼 一致 0000 1010
~ 取反 補碼 1111 0101 是個負數
反碼 1111 0100
原碼 1000 1011 計算機顯示輸出的(-11)

128 明顯超過的了範圍 ,會溢位截斷
原碼與補碼一致
0111 1111 (127)
+1
補碼 1000 0000
反碼 0111 1111
原碼 1000 0000 (-0) == -128

下面的 是關於unsigned 與 signed 的講解

     ANSI C規定在無符號整數和有符號整數之間進行強制型別轉換時,位模式不應該改變。型別轉換並未改變物件的位模式,改變的是位模式的解釋方式。     有符號數轉換為無符號數時,負數轉換為大的正數(可以理解為原值加上2的n次方),而正數保持不變。     無符號數轉換為有符號數時,對於小的數將保持原值,對於大的數則轉換為負數(可以理解為原值減去2的n次方)。
     預設資料型別是signed 的,
#include<stdio.h>
int main()

{
     char a   = -127;
     printf("%d\n",a);

     unsigned char b = -127;
     printf("%d\n",b);

     char c = -127;
     printf("%u\n",c);     //結果是未定義的  ,因為%u是無符號的十進位制輸出
                           //要得到無符號的資料,必須以下方式,先轉化無符號數
     unsigned char d = -127;
     printf
("%u\n",d); } 執行結果: -127 129 4294967169 129 Press any key to continue

講解:

-127 原碼 1111 1111
反碼 1000 0000
補碼 1000 0001
轉成unsigned 型的
就是 1000 0001 ==(129)

轉換說明符:

  %a(%A)     浮點數、十六進位制數字和p-(P-)記數法(C99)
  %c             字元
  %d             有符號十進位制整數
  %f              浮點數(包括float和doulbe)
  %e(%E)     浮點數指數輸出[e-(E-)記數法]
  %g(%G)     浮點數不顯無意義的零"0"
  %i              有符號十進位制整數(與%d相同)
  %u             無符號十進位制整數
  %o             八進位制整數    e.g.     0123
  %x(%X)      十六進位制整數<?xml:namespace prefix = st1 />()   e.g.   0x1234
  %p             指標
  %s             字串
  %%            "%"

格式字串(格式)
〔標誌〕〔輸出最少寬度〕〔.精度〕〔長度〕型別
“%-md” :左對齊,若m比實際少時,按實際輸出。
“%m.ns”:輸出m位,取字串(左起)n位,左補空格,當n>m or m省略時m=n
e.g. “%7.2s” 輸入CHINA
  輸出” CH”
“%m.nf”:輸出浮點數,m為寬度,n為小數點右邊數位
e.g. “%” 輸入3852.99
輸出3853.0
長度:為h短整形量,l為長整形量

printf的格式控制的完整格式:
% - .n l或h 格式字元
下面對組成格式說明的各項加以說明:
①%:表示格式說明的起始符號,不可缺少。
②-:有-表示左對齊輸出,如省略表示右對齊輸出。
③0:有0表示指定空位填0,如省略表示指定空位不填。
④m.n:m指域寬,即對應的輸出項在輸出裝置上所佔的字元數。N指精度。用於說明輸出的實型數的小數位數。為指定n時,隱含的精度為n=6位。
⑤l或h:l對整型指long型,對實型指double型。h用於將整型的格式字元修正為short型。

格式字元
格式字元用以指定輸出項的資料型別和輸出格式。
①d格式:用來輸出十進位制整數。有以下幾種用法:
%d:按整型資料的實際長度輸出。
%md:m為指定的輸出欄位的寬度。如果資料的位數小於m,則左端補以空格,若大於m,則按實際位數輸出。
%ld:輸出長整型資料。
②o格式:以無符號八進位制形式輸出整數。對長整型可以用”%lo”格式輸出。同樣也可以指定欄位寬度用“%mo”格式輸出。
例:
main()
{ int a = -1;
printf(“%d, %o”, a, a);
}
執行結果:-1,177777
程式解析:-1在記憶體單元中(以補碼形式存放)為(1111111111111111)2,轉換為八進位制數為(177777)8。
③x格式:以無符號十六進位制形式輸出整數。對長整型可以用”%lx”格式輸出。同樣也可以指定欄位寬度用”%mx”格式輸出。
④u格式:以無符號十進位制形式輸出整數。對長整型可以用”%lu”格式輸出。同樣也可以指定欄位寬度用“%mu”格式輸出。
⑤c格式:輸出一個字元。
⑥s格式:用來輸出一個串。有幾中用法
%s:例如:printf(“%s”, “CHINA”)輸出”CHINA”字串(不包括雙引號)。
%ms:輸出的字串佔m列,如字串本身長度大於m,則突破獲m的限制,將字串全部輸出。若串長小於m,則左補空格。
%-ms:如果串長小於m,則在m列範圍內,字串向左靠,右補空格。
%m.ns:輸出佔m列,但只取字串中左端n個字元。這n個字元輸出在m列的右側,左補空格。
%-m.ns:其中m、n含義同上,n個字元輸出在m列範圍的左側,右補空格。如果n>m,則自動取n值,即保證n個字元正常輸出。
⑦f格式:用來輸出實數(包括單、雙精度),以小數形式輸出。有以下幾種用法:
%f:不指定寬度,整數部分全部輸出並輸出6位小數。
%m.nf:輸出共佔m列,其中有n位小數,如數值寬度小於m左端補空格。
%-m.nf:輸出共佔n列,其中有n位小數,如數值寬度小於m右端補空格。
⑧e格式:以指數形式輸出實數。可用以下形式:
%e:數字部分(又稱尾數)輸出6位小數,指數部分佔5位或4位。
%m.ne和%-m.ne:m、n和”-”字元含義與前相同。此處n指資料的數字部分的小數位數,m表示整個輸出資料所佔的寬度。
⑨g格式:自動選f格式或e格式中較短的一種輸出,且不輸出無意義的零。