-
1 # 用戶8711930819321
-
2 # 髒話比謊話乾淨558
1、char取值範圍是 -128~+127。
2、我們先來看 signed char的最大值。 最高位是 符號位, 0 代表正數; 1 代表負數。0 1 1 1 1 1 1 1 這個值等於 2^0 + 2^1 + 2^2 + 2^3 + 2^4 + 2^5 + 2^6 = 127 。 也有一個簡便計算方法:2^7 -1 = 128-1 =127 所以,signed char 的最大值是 127 。
singed char 的最小值計算。 在計算機中,數值是以補碼形式存儲的。正數的補碼是其本身; 而負數的補碼是 取反 (符號位保持不變),再加1。
我們先來看 -1 的存儲過程:
-1: 1 0 0 0 0 0 0 1 ->(取反) 1 1 1 1 1 1 1 0 ->(加1) 1 1 1 1 1 1 1 1
-2: 1 0 0 0 0 0 1 0 ->(取反) 1 1 1 1 1 1 0 1 ->(加1) 1 1 1 1 1 1 1 0
-3: 1 0 0 0 0 0 1 1 ->(取反) 1 1 1 1 1 1 0 0 ->(加1) 1 1 1 1 1 1 0 1
… …
-127 1 1 1 1 1 1 1 1 ->(取反) 1 0 0 0 0 0 0 0 ->(加1) 1 0 0 0 0 0 0 1
-128 1 0 0 0 0 0 0 0 ->(取反) 1 1 1 1 1 1 1 1 ->(加1) 1 0 0 0 0 0 0 0
不管是原碼還是補碼, 總會出現 -0 這個值。 本來 +0 與 -0 是沒有區別的。 但對於存儲器和編譯器來講,總得充分利用每個字節吧, 更不想出現二義性。 所以,將 -0 表示為 -128 , 這樣既增大了signed char 數值的表示範圍,又消除了 -0 的二義性。
所以signed char的取值範圍是 -128~127。
擴展資料
在MYSQL中,字段類型char是指:使用指定長度的固定長度表示的字符串;比如char(8),則數據庫會使用固定的1個字節(八位)來存儲數據,不足8位的字符串在其後補空字符。
字符轉換
在excel中char函數用於返回對應發於數字代碼的字符。其用法:=char(number)
其中,參數number為轉換的字符代碼,介於0~255之間,char佔一個字節,也就是8個二進制位,但它表示的是有符號的類型,所以表示的範圍是-128~127;uchar表示無符號的類型,所以表示的範圍是0~255。
代數概念
char是characteristic的簡寫,表示一個環或者域的特徵,即最小的非負整數n,使ne=0。(e為單位元) 。
回覆列表
C語言中char的取值範圍是[-128,127]。
C語言中char表示的是具有一個字節大小的有符號數。有符號數的二進制表示,最高位為1表示的是負數,最高位是0則表示的為非負整數。
比如,假設我們有兩個bit位,那麼能表示的二進制數為00 01 10 11。其中前兩個對應數字0和1,後兩個對應數字-2和-1,它能表示的數的範圍為[-2,1]。以此類推,假設對應的bit為N,則所表示的數的範圍為[-2的N-1次方,2的N-1次方-1]。對應char,N=8,能表示的數的範圍是[-2的7次方,2的7次方-1],也就是[-128,127]。