c語言long和long long的取值範圍

2021-09-17 08:52:49 字數 1764 閱讀 3663

溢位和取值範圍

c語言的整型溢位問題

整數溢位

《c和指標》中寫過:long與int:標準只規定long不小於int的長度,int不小於short的長度。

double與int型別的儲存機制不同,long int的8個位元組全部都是資料位,而double是以尾數,底數,指數的形式表示的,類似科學計數法,因此double比int能表示的資料範圍更廣。

long long在win32中是確實存在,長度為8個位元組;定義為long64。

為什麼會出現long int呢?在win32現在系統中,長度為4;在歷史上,或者其他某些系統中,int長度為2,是short int。

即便是long long,在ti的有款平台中,長度為5也就是說,每種型別長度,需要sizeof才知道,如果可能,最好用union看看裡面的資料,可以消除一些型別的假象長度。

型別名稱

位元組數取值範圍

signed char

1-128~+127

short int

2-32768~+32767

int4

-2147483648~+2147483647

long int

4-2147483648~+2147483647

long long int

8-9223372036854775808~+9223372036854775807

unsigned int (unsigned long)

int (long)

unsigned long (unsigned __int64)

long long (__int64)

最大值、最小值

在#include存有各個型別的最大值和最小值

表示型別

char_min

char的最小值

schar_max

signed char 最大值

schar_min

signed char 最小值

uchar_max

unsigned char 最大值

shrt_max

short 最大值

shrt_min

short 最小值

ushrt_max

unsigned short 最大值

int_max

int 最大值

int_min

int 最小值

uint_max

unsigned int 最大值

uint_min

unsigned int 最小值

long_max

long最大值

long_min

long最小值

ulong_max

unsigned long 最大值

flt_mant_dig

float 型別的尾數

flt_dig

float 型別的最少有效數字位數

flt_min_10_exp

帶有全部有效數的float型別的負指數的最小值(以10為底)

flt_max_10_exp

float型別的正指數的最大值(以10為底)

flt_min

保留全部精度的float型別正數最小值

flt_max

float型別正數最大值

**《c語言long和long long的取值範圍》

C 中的long與C 中的long

微軟很厲害,c 是非常優秀的計算機語言,c 比c 還厲害,c c 本身不就包含四個 號嗎?而微軟發明了c c 中的long比c 中的long要long兩倍!不信你看 我正在使用.net寫乙個預約排隊的程式,因為一前通過vc編寫了乙個用於顯示登記資訊的控制項,現在使用c 重新預約程式,則必然要呼叫vc...

long和int的區別

short與long兩個限定符的引入可以為我們提供滿足實際需要的不同長度的整形數。int通常代表特定機器中證書的自然長度。short型別通常為16位,long型別通常為32位,int型別可以為16位或32位。各編譯器可以根據硬體特性自主選擇合適的型別長度,但要遵循下列限制 short與int型別至少...

long和int的區別

突然間就想到了 long 和int google 各種查詢,各種書籍 c primer c 程式語言 檢視,終於明白了一些。下面的話選自 c程式語言 short 與long兩個限定符的引入可以為我們提供滿足實際需要的不同長度的整形數。int通常代表特定機器中證書的自然長度。short型別通常為16位...