1. java语言有几种数据类型怎样申明和赋值
一、基本数据类型
整型:byte、short、int、long (在计算机中以二进制补码格式存储)
浮点型:float、double (在计算机中以IEEE754格式存储)
字符型:char (在计算机中以unicode码格式存储)
布尔型:boolean (只有true和false两个值)
二、 1.长整型:long
定义:long a=100;int b=a; (编译出错)
给a重新赋值:long a=2147483648; (编译出错)
定义:long a=2147483648L;(正确,说明此时可以是long型的取值范围)
说明在long型的数据后不加L/l时,数据仍为long型,但其取值范围却是int型的取值范围;数据后加L/l时,取值范围才是long型的取值范围。
2.浮点型:long
定义:float a=19; 输出a时为19.0
定义:float a=19.1; (编译出错)
定义:float a=19.1f; (正确)
说明在 float型的数据后不加F/f,则数据不能有小数位,但输出时,能够输出一位小数;若在float型的数据后加上F/f,则数据可以有小数位;
三、类型转换(注:boolean型不会发生类型转换,基本类型和复合类型不能相互转换)
1.自动转换
1)赋值转换:用于短字节的数据类型转换成长字节的数据类型(byte型的数据不能转换成char型,short型和char型数据也不能相互转换)
2)单目运算符提升
++、——运算符不会自动提升,+(正)、-(负)会将byte、short、char型的数据自动转换成int型的数据
3)双目运算符提升
如果有一个操作数是double型的,则把另一个转换成double型;否则如果有一个操作数是float型的,则把另一个转换成float型;否则 如果有一个操作数是long型的,则把另一个转换成long型;否则两个操作数都转换成int型。
4)三目运算符<op1> ? <op2> : <op3>其中op1必须是boolean型的,而op2和op3两操作数必须是能够自动转换成相同类型的数据,op2和op3会自动提升为两操作数中字节较长的一个,并且结果为提升后的类型。
如:byte a1=20;
short a2=10;
boolean b=true;
short c = b ?
a1 : a2;
结果为short型的数据c
2.强制转换
例子:
int a;
byte b=(byte)a;
定义:a=-126;
(分析:int形的数据有4个字节,而byte形的数据只有1个字节,所以只取int型数据的最后一个字节)
a的原码: 10000000,00000000,00000000,01111110
补码: 11111111,11111111,11111111,10000010
法一:r=(10000010)=130 (此时将 10000010 看成是纯的二进制数去计算,而不考虑它的符号位); byte型数据范围〔-128,127〕,由于 r>127,所以 r=r-M (若整型数据值域[-L,R],则M=L+R+1),如果r还不在byte型数据的取值范围内,则继续 r=r-M 直至r在其取值范围内,取得r后,即为byte型的 b .此处r=-126,所以输出b为-126.
法二:直接将int型数据的最后一个字节看成是byte型数据的补码形式,在将补码转换成原码,即得到 b
四、逻辑运算符
1.&&和|| (&&的优先级要高于||的)
特点:只要左操作数已经得出整个表达式的值,就不再计算右操作数的之值,左右操作数必须为boolean型的。
例子:
boolean test1= ++x==-1 && ++x==1 || ++x=2;
boolean test2= ++y==-1 || ++y==1 && ++y=2;
System.out.println(x+" "+test1);
System.out.println(y+" "+test2);
结果:1 false
2 true
2.&和| (逻辑位运算符)
特点:先把两个操作数的值计算出来,然后再进行逻辑运算
int x=-1,y=-1;
boolean test1= ++x==-1 & ++x==1 | ++x=2;
boolean test2= ++y==-1 | ++y==1 & ++y=2;
System.out.println(x+" "+test1);
System.out.println(y+" "+test2);
结果: 2 false
2 true
五、移位运算
<< (左移)高位丢失、低位以0填充
>> (右移) 低位丢失、高位以符号位填充
>>> (无符号位右移) 低位丢失、高位以0填充
此运算符不会对左右两操作数作算术提升,但会对左操作数进行单独提升,若为byte、short、char、int型,则得到结果为int型,若为long型,则结果为long型,但左右操作数均不能为浮点型,否则出错。
当左操作数为int型时,右操作数的低5位才有用,这样可以防止移位超过int型所具有的位数,当左操作数为long型时,右操作数的低6位才有用。
例子:
int a=-2;
short b=-10;
int c=a>>b;
b的补码:11111111,11111111,11111111,11110110
取b的最后5位, r=(10110)=22;
a的补码:11111111,11111111,11111111,11111110
将a向右移动22位,再在高位补上1,得到 11111111,11111111,11111111,11111111 ,转换成原码得到 c=-1
六、赋值运算
1.简单赋值运算
表达式: <变量>=<表达式>
左操作数可以事先没有赋值
表达式的类型必须和变量的类型相同,或能赋值转换成变量的类型,
2.组合赋值运算
表达式:<变量> op= <表达式>
int a=10;
double b=23.3;
a*=b;
左操作数事先一定要赋值
左边的类型和右边的类型不一定要相同,此处a*b得到的是double型的,组合运算符会自动把double型的值转换成int型的值存入变量a中。
2. JAVA鐨勫熀鏈鏁版嵁绫诲瀷鍜屽紩鐢ㄦ暟鎹绫诲瀷鐨勫尯鍒
JAVA鐨勫熀鏈鏁版嵁绫诲瀷鍜屽紩鐢ㄦ暟鎹绫诲瀷鐨勫尯鍒锛
1銆佸熀鏈鏁版嵁绫诲瀷鏈夛細byte锛欽ava涓鏈灏忕殑鏁版嵁绫诲瀷锛泂hort锛氱煭鏁村瀷锛沬nt锛氭暣鍨嬶紱long锛氶暱鏁村瀷锛沠loat锛氭诞鐐瑰瀷锛沝ouble锛氬弻绮惧害娴鐐瑰瀷锛沜har锛氬瓧绗﹀瀷锛沚oolean锛氬竷灏旂被鍨嬨
寮曠敤鏁版嵁绫诲瀷鏈夛細绫汇佹帴鍙g被鍨嬨佹暟缁勭被鍨嬨佹灇涓剧被鍨嬨佹敞瑙g被鍨嬨
2銆佸熀鏈鏁版嵁绫诲瀷鍦ㄨ鍒涘缓鏃讹紝鍦ㄦ爤涓婄粰鍏跺垝鍒嗕竴鍧楀唴瀛橈紝灏嗘暟鍊肩洿鎺ュ瓨鍌ㄥ湪鏍堜笂銆
鑰屽紩鐢ㄦ暟鎹绫诲瀷鍦ㄨ鍒涘缓鏃讹紝棣栧厛瑕佸湪鏍堜笂缁欏叾寮曠敤锛堝彞鏌勶級鍒嗛厤涓鍧楀唴瀛橈紝鑰屽硅薄鐨勫叿浣撲俊鎭閮藉瓨鍌ㄥ湪鍫嗗唴瀛樹笂锛岀劧鍚庣敱鏍堜笂闈㈢殑寮曠敤鎸囧悜鍫嗕腑瀵硅薄鐨勫湴鍧銆
3銆佸湪鏁版嵁鍋氫负鍙傛暟浼犻掔殑鏃跺欙紝鍩烘湰鏁版嵁绫诲瀷鏄鍊间紶閫掞紝鑰屽紩鐢ㄦ暟鎹绫诲瀷鏄寮曠敤浼犻掞紙鍦板潃浼犻掞級銆
3. Java瀹氫箟浜嗗摢浜涘熀鏈鏁版嵁绫诲瀷锛熷熀鏈鏁版嵁绫诲瀷鍜屽紩鐢ㄦ暟鎹绫诲瀷鐨勭壒鐐癸紵
1銆佸竷灏斿瀷 - boolean
1锛塨oolean绫诲瀷閫傜敤浜庨昏緫杩愮畻锛屼竴鑸鐢ㄤ簬绋嬪簭娴佺▼鎺у埗锛
2锛塨oolean绫诲瀷鏁版嵁鍙鍏佽竧rue鎴杅alse锛0鎴栭潪0鐨勬暣鏁颁笉鑳芥浛浠true鍜宖alse銆
2銆佸瓧绗﹀瀷 - char
1锛塩har鍨嬫暟鎹鐢ㄦ潵琛ㄧず閫氬父鎰忎箟涓婄殑鈥滃瓧绗︹濓紱
2锛夊瓧绗﹀父閲忎负鐢ㄥ崟寮曞彿鎷璧锋潵鐨勫崟涓瀛楃︼紱
3锛塉ava瀛楃﹂噰鐢║nicode缂栫爜锛屾瘡涓瀛楃﹀崰涓や釜瀛楄妭锛屽洜鑰屽彲鐢ㄥ崄鍏杩涘埗缂栫爜褰㈠紡琛ㄧず锛
4锛塉ava璇瑷涓杩樺厑璁镐娇鐢ㄨ浆涔夊瓧绗'\'鏉ュ皢鍏跺悗鐨勫瓧绗﹁浆鍙樹负鍏跺畠鐨勫惈涔夈
3銆佹暣鍨 - int銆乻hort銆乴ong銆乥yte
1锛塉ava鍚勬暣鏁扮被鍨嬫湁鍥哄畾鐨勮〃鏁拌寖鍥村拰瀛楁甸暱搴︼紝鍏朵笉鍙楀叿浣撴搷浣滅郴缁熺殑褰卞搷锛屼互淇濊瘉Java绋嬪簭鐨勫彲绉绘嶆э紱
2锛塉ava璇瑷鏁存暟甯搁噺鐨勪笁绉嶈〃绀哄舰寮忥細
1锛夊崄杩涘埗鏁存暟锛
2锛夊叓杩涘埗鏁存暟锛岃佹眰浠0寮澶达紱
3锛夊崄鍏杩涘埗鏁存暟锛岃佹眰浠0x鎴0X寮澶淬
3锛塉ava璇瑷鐨勬暣鍨嬪父閲忛粯璁や负int绫诲瀷锛屽0鏄巐ong绫诲瀷甯搁噺鍙浠ュ悗鍔'l'鎴'L'锛
4锛塉ava璇瑷涓锛屾墍鏈夋暟閮芥槸甯︾﹀彿鐨勶紙姝c佽礋锛夈
绫诲瀷
瀛樺偍绌洪棿
鍙栧艰寖鍥
byte
1瀛楄妭
-128 ~ 127
short
2瀛楄妭
-215 ~ 215-1
int
4瀛楄妭
-231 ~ 231-1
long
8瀛楄妭
-263 ~ 263-1
4銆佹诞鐐瑰瀷 - float銆乨ouble
1锛変笌鏁存暟绫诲瀷绫讳技锛孞ava娴鐐圭被鍨嬫湁鍥哄畾鐨勮〃鏁拌寖鍥村拰瀛楁甸暱搴︼紱
2锛塉ava娴鐐圭被鍨嬪父閲忔湁涓ょ嶈〃绀哄舰寮忥細
1锛夊崄杩涘埗鏁板舰寮忥紱
2锛夌戝﹁℃暟娉曞舰寮忥紱
3锛塉ava娴鐐圭被鍨嬪父閲忛粯璁や负double绫诲瀷锛屽傝佸0鏄庝竴涓甯搁噺涓篺loat绫诲瀷锛屽垯闇瑕佸湪鏁板瓧鍚庨潰鍔'f'鎴'F'锛
4锛塮loat绫诲瀷鐨勭簿搴︿负6-7浣嶏紝double绫诲瀷鐨勭簿搴︿负15浣嶃
绫诲瀷
瀛樺偍绌洪棿
鍙栧艰寖鍥
float
4瀛楄妭
-3.403E38 ~ 3.403E38
double
8瀛楄妭
-1.798E308 ~ 1.798E308
4. Java的基本数据类型有哪些
整数类型:
byte:字节占用 1字节 8位,用来表达最小的数据单位,储存数据长度为 正负 127;
short:字节占用 2字节 16位,储存数值长度为 -32768-32767
int:字节占用 4字节 32位,最为常用的整数类型,储存长度为,-2^31-1~2^31 (21 亿)
long:字节占用 8字节 64位,当到达int数值极限时使用,储存长度为 看图片:
浮点数类型:
float:单精度浮点型 32位 取值范围 3.4e-38~3.4e-38
double:双精度浮点型 64位 ,java中默认的浮点类型 取值范围 1.7e-308~1.7e-308
字符类型:
char:16位 ,java字符使用Unicode编码;
布尔类型
boolean : true 真 和 false 假
引用数据类型:
类 class
接口 interface
5. Java中基本数据类型有哪些
byte:8位,最大存储数据量是255,存放的数据范围是-128~127之间。
short:16位,最大内数据存储量是容65536,数据范围是-32768~32767之间。
int:32位,最大数据存储容量是2的32次方减1,数据范围是负的2的31次方到正的2的31次方减1。
long:64位,最大数据存储容量是2的64次方减1,数据范围为负的2的63次方到正的2的63次方减1。
float:32位,数据范围在3.4e-45~1.4e38,直接赋值时必须在数字后加上f或F。
double:64位,数据范围在4.9e-324~1.8e308,赋值时可以加d或D也可以不加。
boolean:只有true和false两个取值。
char:16位,存储Unicode码,用单引号赋值。