免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1164 | 回复: 0
打印 上一主题 下一主题

java数据类型及使用方法 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-11-05 19:46 |只看该作者 |倒序浏览
一、基本数据类型
    整型: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必须是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型的。
  例子: 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);
结果: 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填充
   此运算符不会对左右两操作数作算术提升,但会对左操作数进行单独提升,若为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中。
               
               
               

本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u2/77840/showart_1361383.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP