java基础知识(一)数据类型(上)

java的数据类型

  

  由上图,java的数据类型分为基本数据类型、引用数据类型两大类。

1、基本数据类型

  与c不同,java的各种数据类型占有固定长度的内存,与具体的软硬件平台无关;另外,每种数据类型都对应一个默认的数值,是的这种数据类型的变量的取值总是确定(存在)的,这两点保证了java的跨平台性和安全稳定性。

  基本数据类型分为4类8种。

  基本数据类型长度

  

  1)逻辑型boolean

    boolean数据类型的值只允许去true或false,不可以用0或非0的整数代替true或false,这是java与c不同的地方。

  2)文本类型char

    字符常量为用单引号括起来的单个字符,java的字符型采用unicode编码(c语言采用ASCII编码,每个数据8比特),每个字符占用2字节,因此可以表示单个字母或汉字,如:

    char c1 = 'a';  char c3 = '中';

    也可用十六进制的形式表示(范围'\u0000'~'\uFFFF')

    char c2 = '\u0061'; char c4 = '\u4e2d'; 

public static void main(String arg[]){
        char c1 = 'a';
        char c2 = '\u0061';
        char c3 = '中';
        char c4 = '\u4e2d';
        System.out.println("c1 = " + c1);
        System.out.println("c2 = " + c2);
        System.out.println("c3 = " + c3);
        System.out.println("c4 = " + c4);
    }

  输出结果如下:

c1 = a
c2 = a
c3 = 中
c4 = 中

  java语言还允许使用转义字符'\'将其后面的字符转换为其它含义(详情参考JAVA中转义字符),如:

  char c5 = '\n'; //代表换行符

  3)整数型(byte、short、int、long)

  • java的整型常量的三种表示形式

  十进制,如:10

  八进制,要求以'0'开头,如:012

  十六进制,要求以'0x'或'0X'开头,如:o10

  注意:上述0、0x或0X,中的0为数字0。

 System.out.println("十进制 :" + 10);
 System.out.println("八进制 :" + 012);
 System.out.println("十六进制 :" + 0xa);

  输出结果

十进制 :10
八进制 :10
十六进制 :10
  • 整型常量按长度不同又可分为一般整型常量(int,32位)和长整型常量(long,64位,尾部有一个大写的L或小写的l)

  4)浮点型(float、double)

  浮点型常量表示的是可以含有小数部分的数值常量,据长度不同分为浮点常量(32位,用F或f表示,如19.4F,3.0513E3,8701.52f)和双精度常量(64位,用D或d表示,如2.433E-5D,3.1415d)。同其它高级语言一样,浮点常量有一般表示法和指数表示法两种。

System.out.println(314F);
System.out.println(314D);
System.out.println(3.14e2);

System.out.println(7.273F);
System.out.println(7.273D);

  输出结果

314.0
314.0
314.0
7.273
7.273
  • 最后

  浮点数在机内用指数型式表示,分解为:数符,尾数,指数符,指数四部分。
  数符占1位二进制,表示数的正负。
  指数符占1位二进制,表示指数的正负。
  尾数表示浮点数有效数字,0.xxxxxxx,但不存开头的0和点
  指数存指数的有效数字。

  指数占多少位,尾数占多少位,由计算机系统决定。
  可能是数符加尾数占24位,指数符加指数占8位 -- float.
  数符加尾数占48位,指数符加指数占16位 -- double.

  知道了这四部分的占位,按二进制估计大小范围,再换算为十进制,就是浮点数的数值范围。

  对编程人员来说,double 和 float 的区别是double精度高,有效数字16位,float精度7位。但double消耗内存是float的两倍,double的运算速度比float慢得多,java语言中数学函数名称double 和 float不同,不要写错,能用单精度时不要用双精度(以省内存,加快运算速度)。

2、数值型数据类型间的相互转换

  

  图中3个虚线表示可能有精度损失的转换,例如,123456789是一个大整数,它所包含的位数比float类型所能够表达的位数多。当将这个整型数值转换为float类型时,将会得到同样大小的结果,但却失去了一定的精度。

public static void main(String arg[]){
        int n = 123456789l;
        float f = l;
        System.out.println("int= " + n);
        System.out.println("float = " + f);

    }

  结果

int= 123456789
float = 1.23456792E8

  当使用上面两个数值进行二元操作时(例如 n+f  , n是整数,f是浮点数),先要将两个操作数转换为同一种类型,然后再进行计算。

  如果两个操作数中有一个是double类型,另一个操作数就会转换为double类型;

  否则,如果其中一个操作数是float类型,另一个操作数将会转换为float类型;

  否则,如果其中一个操作数是long类型,另一个操作数将会转换为long类型。

  否则,两个操作数都将被转换为int类型。

  • 强制转换

  强制转换的格式是在需要转型的数据前加上“( )”,然后在括号内加入需要转化的数据类型。有的数据经过转型运算后,精度会丢失,而有的会更加精确。例如:

public static void main(String arg[]){
double d = 9.99;
int i = (int)d;
System.out.println("d = " + d);
System.out.println("i = " + i);

}

  结果

d = 9.99
i = 9

警告:如果试图将一个数值从一种类型强制转换为另一种类型,而又超出了目标类型的表示范围,结果就会截断成一个完全不同的值

     不要在boolean类型与任何类型之间进行强制类型转换,这样可以防止发生错误。

posted @ 2016-11-08 23:01  code.world  Views(677)  Comments(0Edit  收藏  举报