目录
三个特殊的浮点数:正无穷大(Double.POSITIVE_INFINITY)、负无穷大(Double.NEGATIVE_INFINITY)、NaN(DOuble.NaN不是数字)
浮点数误差System.out.println(2.0 - 1.1) == 0.89999999……not 0.9
思考:short a = 1; short b = 2; 那么a+b 是什么类型
CMD编译java文件中有中文,报错java80:编码GBK的不可映射字符
-
学习4类8种 java数据类型
-
使用基本数据类型实现简单的四则运算,并打印结果,例如 int a = 1; int b = 1; int sum = a + b;
-
类型转换。例如 int转byte,要求全部8种数据类型都自己练习转换至少一次,看看是否报错。思考:short a = 1; short b = 2; 那么a+b 是什么类型
-
学习什么是实例变量、什么是静态变量
-
学习Java修饰符,private | protected | public,static、final、abstract、synchronized、transient、volatile 明确其使用场景和注意事项
-
设计一个Java对象class Animal,包含成员变量:名字 String name、年龄 int age、身高 float height,包含静态变量 String feature = "动物都会动";
-
在main方法中实例化对象Animal,设置它的属性值
-
在CMD中打印Animal所有的属性值
1、四类八种基本数据类型:
布尔型:boolean
字符型:char
整数型:byte,short,int,long
浮点数型:float,double
Float和Double的最小值和最大值都是以科学记数法的形式输出的,结尾的“E+数字”表示E之前的数字要乘以10的多少倍。比如3.14E3就是3.14×1000=3140,3.14E-3就是3.14/1000=0.00314。
1.1 整型
长整型后缀L或l;十六进制前缀0x或0x(0xCA == 202);八进制前缀0(010 == 8)。
Java7及以上版本:二进制前缀0b或0B(0b10 == 2);数组可以加下划线,不影响结果,编译器自动去除(1_000 == 1000)。
Java没有任何无符号int等类型,必须要用也可以,必比如byte b表示0~255,加减乘除不溢出都可以正常运算,其他运算需要调用Byte.toUnsignedInt(b),Integer和Long类都提供处理无符号除法和求余的方法。
1.2 浮点型
double精度是float两倍(双精度),float后缀f或F,没有后缀(1.23)默认double类型,douuble可后缀d或D。
可以使用十六进度表示浮点数值(0.125 == 2^(-3)、0.125 == 0x1.0p-3),尾数十六进制,指数十进制,指数的基是2。
三个特殊的浮点数:正无穷大(Double.POSITIVE_INFINITY)、负无穷大(Double.NEGATIVE_INFINITY)、NaN(DOuble.NaN不是数字)
0/0(或负数的平方根) == NaN。
if (x == Double.NaN) // is never true
if (Double.isNaN(x)) // check whether x is "not a number"
浮点数误差System.out.println(2.0 - 1.1) == 0.89999999……not 0.9
二进制系统无法精确表示1/10,十进制无法表示1/3同理。
解决办法,使用BigDecimal类。
1.3 char类型
转义字符\u unicode字符(‘A’ == 65)
常用转义字符表
特别注意:1.转义序列在解析代码前就会被处理
2.注意注释中的\u
例如:1. \u0022 + \u0022 == " + " ,结果为空;
2. //\u00A is a new line
// C:\users 出现了转义字符却没有四个十六进制数
1.4 boolen
整形和布尔类型不能相互转换
2、类型转换
类型转换。例如 int转byte,要求全部8种数据类型都自己练习转换至少一次,看看是否报错。
public class Day21 {
private static void transdata(){
System.out.println("******基本数据类型转换,小字节类型向大字节类型转换( 顺序char->int -> long -> float -> double)****");
boolean a = true;
char b = 'A';
byte c = 1;
short d = 2;
int e = 3;
long f = 4;
double g = 5.67;
System.out.println(a);
System.out.println((int) b);
System.out.println((short) c + d);
System.out.println((int) d + e);
System.out.println((long) e + f);
System.out.println((double) f + g);
}
public static void main(String[] args){
transdata();
}
}
思考:short a = 1; short b = 2; 那么a+b 是什么类型
int类型,放不下小字节类型向大字节类型转换( 顺序char->int -> long -> float -> double)
3、实例变量、静态变量
Java中并不区分声明和定义(C++中int i || extern int i)
从Java10局部变量可以自动推断,用var(var i = 10;var i = true)
关键字final指示常量,赋值后不能修改;类常量static final可以在一个类的多个方法中使用,public static final使其它类方法也能用。
静态变量也叫做类变量,独立于方法之外的变量,有static修饰。实例变量同样也是独立于方法之外的变量,但没有static修饰。实例变量属于某个对象的属性,必须创建了实例对象,其中的实例变量才会被分配空间,才能使用这个实例变量。静态变量不属于某个实例对象,而是属于整个类。只要程序加载了类的字节码,不用创建任何实例对象,静态变量就回被分配空间,静态变量就可以被使用了。
4、Java修饰符
学习Java修饰符,private | protected | public,static、final、abstract、synchronized、transient、volatile 明确其使用场景和注意事项
Java语言提供了很多修饰符,主要分为以下两类:
- 访问修饰符
- 非访问修饰符
https://www.w3schools.cn/java/java_modifiers.asphttps://www.w3schools.cn/java/java_modifiers.asp
5、class Animal
设计一个Java对象class Animal,包含成员变量:名字 String name、年龄 int age、身高 float height,包含静态变量 String feature = "动物都会动";
class Animal {
String name;
int age;
float height;
static String feature = "动物都会动";
}
6、实例化对象Animal
在main方法中实例化对象Animal,设置它的属性值
Animal animal = new Animal();
String newname = animal.name = "Lihua";
int newage = animal.age = 18;
float newheight = animal.height = 180;
7、在CMD中打印Animal所有的属性值
System.out.println(newname);
System.out.println(newage);
System.out.println(newheight);
System.out.println(Animal.feature);
完整代码
class Animal {
String name;
int age;
float height;
static String feature = "动物都会动";
}
public class Day21 {
private static void data(){
System.out.println("******************************基本数据类型********************************");
System.out.println("基本类型:byte 二进制位数:" + Byte.SIZE);
System.out.println("包装类:java.lang.Byte");
System.out.println("最小值:Byte.MIN_VALUE=" + Byte.MIN_VALUE);
System.out.println("最大值:Byte.MAX_VALUE=" + Byte.MAX_VALUE);
System.out.println();
// short
System.out.println("基本类型:short 二进制位数:" + Short.SIZE);
System.out.println("包装类:java.lang.Short");
System.out.println("最小值:Short.MIN_VALUE=" + Short.MIN_VALUE);
System.out.println("最大值:Short.MAX_VALUE=" + Short.MAX_VALUE);
System.out.println();
// int
System.out.println("基本类型:int 二进制位数:" + Integer.SIZE);
System.out.println("包装类:java.lang.Integer");
System.out.println("最小值:Integer.MIN_VALUE=" + Integer.MIN_VALUE);
System.out.println("最大值:Integer.MAX_VALUE=" + Integer.MAX_VALUE);
System.out.println();
// long
System.out.println("基本类型:long 二进制位数:" + Long.SIZE);
System.out.println("包装类:java.lang.Long");
System.out.println("最小值:Long.MIN_VALUE=" + Long.MIN_VALUE);
System.out.println("最大值:Long.MAX_VALUE=" + Long.MAX_VALUE);
System.out.println();
// float
System.out.println("基本类型:float 二进制位数:" + Float.SIZE);
System.out.println("包装类:java.lang.Float");
System.out.println("最小值:Float.MIN_VALUE=" + Float.MIN_VALUE);
System.out.println("最大值:Float.MAX_VALUE=" + Float.MAX_VALUE);
System.out.println();
// double
System.out.println("基本类型:double 二进制位数:" + Double.SIZE);
System.out.println("包装类:java.lang.Double");
System.out.println("最小值:Double.MIN_VALUE=" + Double.MIN_VALUE);
System.out.println("最大值:Double.MAX_VALUE=" + Double.MAX_VALUE);
System.out.println();
// char
System.out.println("基本类型:char 二进制位数:" + Character.SIZE);
System.out.println("包装类:java.lang.Character");
// 以数值形式而不是字符形式将Character.MIN_VALUE输出到控制台
System.out.println("最小值:Character.MIN_VALUE="+ (int) Character.MIN_VALUE);
// 以数值形式而不是字符形式将Character.MAX_VALUE输出到控制台
System.out.println("最大值:Character.MAX_VALUE="+ (int) Character.MAX_VALUE);
System.out.println();
}
private static void transdata(){
System.out.println("******基本数据类型转换,小字节类型向大字节类型转换( 顺序char->int -> long -> float -> double)****");
boolean a = true;
char b = 'A';
byte c = 1;
short d = 2;
int e = 3;
long f = 4;
double g = 5.67;
System.out.println(a);
System.out.println((int) b);
System.out.println((short) c + d);
System.out.println((int) d + e);
System.out.println((long) e + f);
System.out.println((double) f + g);
}
public static void main(String[] args){
data();
transdata();
System.out.println("******设计一个Java对象class Animal,在main方法中实例化对象Animal,设置它的属性值,并打印****");
Animal animal = new Animal();
String newname = animal.name = "Lihua";
int newage = animal.age = 18;
float newheight = animal.height = 180;
System.out.println(newname);
System.out.println(newage);
System.out.println(newheight);
System.out.println(Animal.feature);
}
}
完整代码运行结果
******************************基本数据类型********************************
基本类型:byte 二进制位数:8
包装类:java.lang.Byte
最小值:Byte.MIN_VALUE=-128
最大值:Byte.MAX_VALUE=127
基本类型:short 二进制位数:16
包装类:java.lang.Short
最小值:Short.MIN_VALUE=-32768
最大值:Short.MAX_VALUE=32767
基本类型:int 二进制位数:32
包装类:java.lang.Integer
最小值:Integer.MIN_VALUE=-2147483648
最大值:Integer.MAX_VALUE=2147483647
基本类型:long 二进制位数:64
包装类:java.lang.Long
最小值:Long.MIN_VALUE=-9223372036854775808
最大值:Long.MAX_VALUE=9223372036854775807
基本类型:float 二进制位数:32
包装类:java.lang.Float
最小值:Float.MIN_VALUE=1.4E-45
最大值:Float.MAX_VALUE=3.4028235E38
基本类型:double 二进制位数:64
包装类:java.lang.Double
最小值:Double.MIN_VALUE=4.9E-324
最大值:Double.MAX_VALUE=1.7976931348623157E308
基本类型:char 二进制位数:16
包装类:java.lang.Character
最小值:Character.MIN_VALUE=0
最大值:Character.MAX_VALUE=65535
******基本数据类型转换,小字节类型向大字节类型转换( 顺序char->int -> long -> float -> double)****
true
65
3
5
7
9.67
Lihua
18
180.0
动物都会动
Process finished with exit code 0
CMD编译java文件中有中文,报错java80:编码GBK的不可映射字符
解决办法:以UTF-8格式为例,javac -encoding utf-8 XXX.java
成功解决