Java语言基础——数据类型

 Java  数据类型
   java 中的数据类型,分引用类型基本数据类型,基本数据类型有 8 种 ,引用类型将在面向对象时详细讲解,此处了解即可。
1 . 8种基本数据类型
 整形: byte, short, int, long
 浮点形:   float, double
 字符型:   char
 Boolean型:   boolean

2 .整数类型
整数类型有byte, short, int ,long都是有符号(补码)整数(即能表示负数).

类型 占位 最大值 最小值
byte  8位补码 0x7f(127) 0x80(-128)
short 16位有符号数 0x7fff(32767)  0x8000(-32768)
int 32位   0x7fffffff(2G-1)2^31-1 或21亿   0x80000000(-2G)
long 64位  2^63-1 -2^63


例:

//byte b = 128;  超范围赋值,会报编译错误
byte b = 127;
byte c = -128;

short s = 32767;
//short s2 = 0x8000; //错误,超范围
short s2 = 0xffff8000;  //可以,最小值


long 类型的字面量需要使用"L"或者"l"后缀,否则编译不同过,因为整数值的默
认字面值是int 类型,12123123123明显超出了int 的范围,所以报错,但是在后
面加L,则表示该数是long类型的
例:

1  public class BinDemo{
2   public static void main(String[] args){
3    long l1 = 12123123123;//报错
4    long l2 = 12123123123L;//正确
5   }
6  }



3.3浮点数类型
 用于表示小数的数据类型。浮点数原理:也就是采用二进制科学奇数发。
 * 10进制浮点数科学计数法: 219345 = 2.19345*5(10^5)
 * 2进制浮点数科学计数法:   10111 = 1.0111*(2^100)
 以2.19345*(10^5) 为例介绍如下概念:
 尾数: .19345
 指数: 5
 基数: 10

 float类型共32位(与int 相同),其中1位为符号位,指数8位,尾数32位。需要强调的是float的精度是23位
    (即能精确表达23位的数,超过就被截取了)。小数是以尾数长度来表示精确度的,比如pi=3.14,它的精度
    是2位,pi = 3.1415,它的精度就是4位。
 比较有趣的是int 的精度比float要大,因为int的精度是31位,大于float.因为int 类型的范围是(-2^31)~(2^31-1)而
    float的范围是(-2^128)~(-2^128-1),所以:
 (此处加黑)int类型的数据能表示的范围比float类型小,int类型数据表示的精度比float大。
例子

 1 /** 浮点数的特点 */
 2 public class FloatDemo{
 3  public static void main(String[] args){
 4   int a = 0x7fffffff;  //int类型最大值
 5   int b = 0x7ffffff0;  //比a大15
 6   
 7   float fa = a;   
 8   float fb = b;
 9   System.out.println(fa);  
10   System.out.println(fb);
11   System.out.println(a==b);  //false int类型的值相比较a>b
12   System.out.println(fa==fb); // ture   相同的数,float类型竟然相同
13  }
14 }


float类型因为精度过低,所以一般很少使用,一般我们使用double

double类型能够表示64位,其中1位是符号位,11位指数,52位尾数

注:浮点数运算时只是尽可能精确,所以不要对浮点数进行比较,比的不准。
例子

/** 浮点数的特点 */
public class FloatDemo{
 public static void main(String[] args){
  int a = 0x7fffffff;  //int类型最大值
  int b = 0x7ffffff0;  //比a大15
  
  float fa = a;   
  float fb = b;
  System.out.println(fa);  
  System.out.println(fb);
  System.out.println(a==b);  //false int类型的值相比较a>b
  System.out.println(fa==fb); // ture   相同的数,float类型竟然相同
 }
}


3.4字符类型char

 字符类型是经常用到的,是16位无符号整数,是一个二进制数,这个数值是一个字符的unicode编码值
 unicode编码,是全国范围内的编码方法,编制了英文,中,日,韩,阿拉伯等8万多个字符(unicode在设计时
就旨能表示世界上所有的文字)
 java中的char 范围是0~65535不能表示全部unicode,但是表示unicode最常用部分够用了
 在程序中为一个字符赋值,字符字面量使用单引号,可以为char赋值的有字符,数字,符号
例子

 1 /** 浮点数的特点 */
 2 public class FloatDemo{
 3  public static void main(String[] args){
 4   int a = 0x7fffffff;  //int类型最大值
 5   int b = 0x7ffffff0;  //比a大15
 6   
 7   float fa = a;   
 8   float fb = b;
 9   System.out.println(fa);  
10   System.out.println(fb);
11   System.out.println(a==b);  //false int类型的值相比较a>b
12   System.out.println(fa==fb); // ture   相同的数,float类型竟然相同
13  }
14 }


输出结果为:
0
a

注意:特殊字符采用[转义字符]表示,如:
 '\n'  表示回车
 '\t'  表示table键
 '\\'  表示\
 '\'' 表示单引号
 '\"'表示双引号
 '\u4e2d'表示unicode 编码对应的字符
当控制台显示为"?"时候,代表本操作系统中找不到该数字对应的字库

并不是所有字符都可见,例如'\u0000'表示为小方块或者不可见

3.5boolean布尔类型
表达:真(true)/假(false).一般用于判断语句块中
例子

public class Demo {
   public static void main(String[] args) {
      boolean kaihui = false;
      if(kaihui == true){
       System.out.println("下班回家");
      }else{
       System.out.println("加班开会");
      }
   }
}
输出结果为:
加班开会


注:true和false不是java关键词

原文地址:https://www.cnblogs.com/hqr9313/p/2439679.html