java,c,c++ 語言之間基本數(shù)據(jù)類型的比較
當(dāng)要進(jìn)行底層移植的時候肯定會遇到這些問題。特整理了下。
java語言基本數(shù)據(jù)類型
在JAVA中一共有八種基本數(shù)據(jù)類型,他們分別是
byte、short、int、long、float、double、char、boolean
整型
其中byte、short、int、long都是表示整數(shù)的,只不過他們的取值范圍不一樣
byte的取值范圍為-128~127,占用1個字節(jié)(-2的7次方到2的7次方-1)
short的取值范圍為-32768~32767,占用2個字節(jié)(-2的15次方到2的15次方-1)
int的取值范圍為(-2147483648~2147483647),占用4個字節(jié)(-2的31次方到2的31次方-1)
long的取值范圍為(-9223372036854774808~9223372036854774807),占用8個字節(jié)(-2的63次方到2的63次方-1)
可以看到byte和short的取值范圍比較小,而long的取值范圍太大,占用的空間多,基本上int可以滿足我們的日常的計算了,而且int也是使用的最多的整型類型了。
在通常情況下,如果JAVA中出現(xiàn)了一個整數(shù)數(shù)字比如35,那么這個數(shù)字就是int型的,如果我們希望它是byte型的,可以在數(shù)據(jù)后加上大寫的B:35B,表示它是byte型的,同樣的35S表示short型,35L表示long型的,表示int我們可以什么都不用加,但是如果要表示long型的,就一定要在數(shù)據(jù)后面加“L”。
浮點型
float和double是表示浮點型的數(shù)據(jù)類型,他們之間的區(qū)別在于他們的精確度不同
float 3.402823e+38 ~ 1.401298e-45(e+38表示是乘以10的38次方,同樣,e-45表示乘以10的負(fù)45次方)占用4個字節(jié)
double 1.797693e+308~ 4.9000000e-324 占用8個字節(jié)
double型比float型存儲范圍更大,精度更高,所以通常的浮點型的數(shù)據(jù)在不聲明的情況下都是double型的,如果要表示一個數(shù)據(jù)是float型的,可以在數(shù)據(jù)后面加上“F”。
浮點型的數(shù)據(jù)是不能完全精確的,所以有的時候在計算的時候可能會在小數(shù)點最后幾位出現(xiàn)浮動,這是正常的。
boolean型(布爾型)
這個類型只有兩個值,true和false(真和非真)
boolean t = true;
boolean f = false;
char型(文本型)
用于存放字符的數(shù)據(jù)類型,占用2個字節(jié),采用unicode編碼,它的前128字節(jié)編碼與ASCII兼容
字符的存儲范圍在\u0000~\uFFFF,在定義字符型的數(shù)據(jù)時候要注意加' ',比如 '1'表示字符'1'而不是數(shù)值1,
char c = ' 1 ';
我們試著輸出c看看,System.out.println(c);結(jié)果就是1,而如果我們這樣輸出呢System.out.println(c+0);
結(jié)果卻變成了49。
如果我們這樣定義c看看
char c = ' \u0031 ';輸出的結(jié)果仍然是1,這是因為字符'1'對應(yīng)著unicode編碼就是\u0031
char c1 = 'h',c2 = 'e',c3='l',c4='l',c5 = 'o';
System.out.print(c1);System.out.print(c2);System.out.print(c3);System.out.print(c4);Sytem.out.print(c5);
String
在前面我們看到過這樣的定義:
String s = "hello";
System.out.println(s);跟上面的5條語句組合起來的效果是一樣的,那么String是個什么呢?String是字符串,它不是基本數(shù)據(jù)類型,它是一個類。
c語言數(shù)據(jù)類型
1.整型數(shù)據(jù)類型
C定義了5種整型數(shù)據(jù)類型。
整型數(shù)據(jù)類型表
序號 類型名稱 說明 字節(jié)數(shù) 取值范圍
1 signed char 有符號的單字節(jié)整數(shù)類型 1 -128~+127
2 short int 短整型 2 -32768~+32767
3 int 整型 4 -2147438648~+2147438647
4 long int 長整型 4 -2147438648~+2147438647
5 long long int 長長整型 8 -9223372036854775808~+-9223372036854775807
2.無符號整數(shù)類型
對應(yīng)有符號類型,還有無符號整數(shù)類型。
無符號整數(shù)類型表
序號 類型名稱 字節(jié)數(shù) 取值范圍
1 unsigned char 1 0~255
2 unsign short int 2 0~65535
3 unsigned int 4 0~4294967295
4 unsigned long int 4 0~4294967295
5 unsign long long int 8 0~18446744073709551615
3.整型常量
整型常量是指用以表示整型數(shù)值的常量,分為短整型(short int)、整型(int)、長整型(long int )和長長整型(long long int)四種。C默認(rèn)整型(int)。 各種類型整型常量進(jìn)制表示表(后綴不區(qū)分大小寫)
序號 數(shù)據(jù)類型 八進(jìn)制 十進(jìn)制 十六進(jìn)制
1 整型 0112 74 0x4a
2 長整型(l) 0112l 74l 0x4al
3 長長整型(ll) 0112ll 74ll 0x4all
4 無符號整型(u) 0112u 74u 0x4au
5 無符號長整型(ul) 0112ul 74ul 0x4aul
6 無符號長長整型(ull) 0112ull 74ull 0x4aull
4.字符數(shù)據(jù)類型
C語言中字符型數(shù)據(jù)只有一種,即char型數(shù)據(jù)。一般也把char直接稱為字符型。字符型占用內(nèi)存空間最少,一般占用一個字節(jié),存儲在char類型變量的整數(shù)可以表示為有符號或無符號的值,這取決于編譯器。
5.字符變量
字符變量是用于存儲字符型數(shù)值的變量。字符型變量也分為兩種:有符號和無符號型。
6.浮點型數(shù)據(jù)類型
C語言定義了三種浮點數(shù)據(jù)類型:
•float,單精度
•double,雙精度
•long double,長雙精度
C標(biāo)準(zhǔn)中對不同類型的浮點數(shù)有不同的規(guī)定,編譯器不同或硬件條件不同,字節(jié)長度也不相同。
浮點型的字節(jié)長度、精度、數(shù)量級范圍和輸出輸入格式表
序號 數(shù)據(jù)類型 字節(jié)長度 精度 數(shù)量級范圍 printf和scanf格式
1 float(f) 4 7 -38~38 %f
2 double 8 約16 -308~308 %f
3 long double(1) 12 約19 -4932~4932 %llf
7.浮點型精度
浮點型精度從低到高排列為float、double和long long double。
8.浮點型的存儲方式
浮點型數(shù)值以科學(xué)計數(shù)法的表示形式存儲在內(nèi)存中。浮點型的內(nèi)存形式包含三個部分:
1)符號位
符號位浮點型的符號位只有一位,為最高位。該位為1,表示負(fù)數(shù),該位為0,為非負(fù)數(shù)。
2)指數(shù)位
浮點型的指數(shù)位以補碼形式存儲,是科學(xué)計數(shù)法的指數(shù)部分。
3)基數(shù)位
基數(shù)位是浮點型的最后一位,這個位決定數(shù)值的精度。
浮點型儲存分段表
序號 數(shù)據(jù)類型 符號位 指數(shù)位 基數(shù)位 偏差值
1 float 1 8 23 127
2 double 1 11 52 1023
3 long double 1 15 64 16383
c++語言基本數(shù)據(jù)類型
C++基本數(shù)據(jù)類型有字符型(char)、整數(shù)類型(int)、浮點型(float)、雙精度型(double)和無值類型(void),下表給出各種基本類型和內(nèi)存中的位數(shù)和表示數(shù)值的范圍(對于字符型存儲的是ASCII碼):
基本數(shù)據(jù)類型
類型 類型名 位數(shù)
范圍
字符型 char 8
-128 ------ 127
整型 int 16
-32768 ------ 32767
浮點型 float 32
3.4E-38 ------ 3.4E+38
雙精度型 double 64
1.7E-308 ------ 1.7E+308
無值類型 void 0
0
類型名前可以加修飾符(void類型除外),修飾符有 signed(帶符號的)、 unsigned(無符號的)、short(短的)和 long(長的)。signed 和 unsigned 用于字符型或整型,short 和long 可用于整型,還可用于雙精度型,如下表所示:
基本數(shù)據(jù)類型和修飾符
類型 類型名 位數(shù)
范圍
字符型 char 8
-128 ------ 127
signed char 8
-128 ------ 127
unsigned char 8
0 ------ 255
整型 int 16
-32768 ------ 32767
signed int 16
-32768 ------ 32767
unsigned int 16
0 ------ 65535
short int 16
-32768 ------ 32767
signed short int 16
-32768 ------ 32767
unsigned short int 16
0 ------ 65535
long int 32
-2,147,483,648 ---- 2,147,483,647
signed long int 32
-2,147,483,648 ---- 2,147,483,647
unsigned long int 32
0 ----------------4,294,967,295
浮點型 float 32
3.4E-38 ------ 3.4E+38
雙精度型 double 64
1.7E-308 ------ 1.7E+308
long double 80
3.4E-4932 ------ 1.1E+4932
當(dāng)用 signed 、unsigned 、short 和 long 修飾 int 時,int 可省略。
字符型實際上是一個字節(jié)的整型,浮點型和雙精度型表示實數(shù)。
注:不同編譯系統(tǒng),整數(shù)的存儲長度不同。對于16位的編譯系統(tǒng),int為2字節(jié);而對于32位的編譯系統(tǒng),int為4字節(jié)??梢杂胹izeof運算符測試。如:
cout<<sizeof(int)<<endl;
輸出結(jié)果是字節(jié)數(shù)。