一、基本数据类型之浮点型

每个数据它自身都有一个默认的类型,如果直接打印小数,默认类型就为double类型;

float和double表示小数的精度不是特别的高,如果对于精确度要求非常的高,我们 都使用BigDecimal类型。

1、float(单精度)

申明数据类型(小数(单精度))

float f = 1.0; 编译报错,因为我们表面上看到时1.0,其实它是无限接近于1.0这个数据。那怎么解决呢? 在数据后面加一个F或者f。float f = 1.0f;告诉java,我1.0这个数据为float类型。

2、Double(双精度)

申明数据类型(小数(双精度))

double d = 1.2;

3、常见小数的表现形式

1.  直接写小数    如:3.2   4.4

2. 使用科学技术法:  3e2===3.0*10(2)    3e-2  3.0*10(-2),注意是3.0!!!

二、基本数据类型之字符类型(只能储存单个字符)

1、字符的默认值是:a,用十六进制来表示是:‘\u0000’

2、常见的形式:

1. 直接编写字符  'A'  '1'  '好'

2. 字符可以用数字(ASCII)来表示(了解): char a = 65

3. 字符可以用16进制来表示:语法格式  '\uXXXX'   XXXX:16进制,如果不够4位用0来填充

三、基本数据类型之布尔类型(1位)

它只有2个值: true/false

怎么定义的呢?

在计算机底层它其实是用1或者0来表示的, 1表示true 0表示false

布尔类型使用场景一般都是在:选择结构  循环结构中

四、引用数据类型之字符串

1、语法格式:String str = “hello world”

2、字符串的+好问题: 它表示连接的意思,字符串和任意的数据都可以连接,得到的最终结果值,还是字符串。

五、基本数据值数据转换问题

byte    short    char    int    long    float     double

从左到右精度越来越高,它会自动隐式转换的

从右到左精度越来越低,如果想要转换,必须进行强转

强转的格式:byte a = (byte)3.2;

注意: 在byte short  char int中,如果你输入一个数据在其范围中,不需要强转,它也是会自动隐式转换的。

六、表达式

表达式:就是由常量,变量,运算符,()组成的

研究,整个表达式应该用什么类型来接收最终的结果值--》答:应该用整个表达式中精 度最高的类型来接收

七、运算符

1、运算符:

+   -   *  /(求商)  %(余数)

++  --(--和++一样)

注意:自增与自减它只能用于变量,不能用于常量

请把a++或者++a看成一个表达式

当++在变量后面的时候,整个表达式的值,是变量自增之前的值

当++在变量前面的时候,整个表达式的值,是变量自增之后的值

不管++在前还是在后,该变量都会自增1

2、赋值运算:

+=: 累加   byte a+=2  就相当于  byte a = (byte)(a+2)
*=
/=
-=
%=

3、比较运算符:

>  >=  == !=   <  <=

比较运算符,最终结果值为布尔类型

4、逻辑运算符:

&   &&   |  ||  ^(异或)  !(逻辑非)

&与&&的区别:  

&它可以用于位运算,也可以用于逻辑运算,而&&只能用于逻辑运算

如果它们都用于逻辑运算表示那么&不具备短路行为,而&&具备短路行为, 所以以后做逻辑运算推荐使用&&,因为性能高

5、三目运算(三元运算):

语法格式:

X:必须是布尔类型的结果值

注意:如果Y与Z的类型一致,可以使用变量接收,否则不行