Java语言学习笔记 CH2
1.接口 接口中所定义的方法都是抽象方法
Java语言学习笔记 CH3
1.数据类型 :原始类型,引用类型
原始类型 :char/numeric/array
numeric : integer/floating-point
integer : int/long/short/byte
float-point : float/double
引用类型:class/interface/array
2.float f = 0.1;//错,0.1默认是都爆了型
boolean b = 1;//错,boolean只能用true赋值
3.final已经赋值不能改变
final int i = 0;//正确
int final i = 0;//错误
Java语言学习 CH4
1.声明并没有创建对象 空引用
2.Point a = new Point(1,2);
Point b = new Point(1,2);
Point c = a;
a==b //flase
a==c //true
3.overload 重载
方法名相同,但参数不同的多个同名函数
注意: 1.参数不同的意思是参数类型、参数个数、参数顺序至少有一个不同
2.返回值和异常以及访问修饰符,不能作为重载的条件(因为对于匿名调用,会出现歧义,eg:void a ()和int a() ,如果调用a(),出现歧义)
3.main方法也是可以被重载的
override 覆盖
子类重写父类的方法,要求方法名和参数类型完全一样(参数不能是子类),返回值和异常比父类小或者相同(即为父类的子类),访问修饰符比父类大或者相同
注意:子类实例方法不能覆盖父类的静态方法;子类的静态方法也不能覆盖父类的实例方法(编译时报错),总结为方法不能交叉覆盖
hide 隐藏
父类和子类拥有相同名字的属性或者方法时,父类的同名的属性或者方法形式上不见了,实际是还是存在的
注意:当发生隐藏的时候,声明类型是什么类,就调用对应类的属性或者方法,而不会发生动态绑定
方法隐藏只有一种形式,就是父类和子类存在相同的静态方法
属性只能被隐藏,不能被覆盖
子类实例变量/静态变量可以隐藏父类的实例/静态变量,总结为变量可以交叉隐藏
隐藏和覆盖的区别:
被隐藏的属性,在子类被强制转换成父类后,访问的是父类中的属性
被覆盖的方法,在子类被强制转换成父类后,调用的还是子类自身的方法
因为覆盖是动态绑定,是受RTTI(run time type identification,运行时类型检查)约束的,隐藏不受RTTI约束,总结为RTTI只针对覆盖,不针对隐藏
特殊情况:
1.final修饰的属性可以被隐藏,但是不能被赋值,即不能用=来赋值,网上说final属性不能被修改,这个说法不准确,因为对于引用类型的变量用final修饰后,它只是不能被指向其他对象,但是可以改它自身的值,可以用ArrayList测试,final属性可以在运行的时候进行初始化,但是不能不出现初始化语句
2.final修饰的方法不能被覆盖,可以被重载
3.final修饰的类不能被继承
4.private 方法隐式添加了final
4.成员:类成员(static成员)+实例成员(非static成员),均包含变量和函数
5.Java的垃圾回收机制:没有引用的对象进行释放
6.Character :单一字符数值类
String :多个字符组成的不可变数据
StringBuffer :存储操作多个字符组成的可变数据
7.Character a = new Character('a');
a.compareTo(new Character('b'));
返回(int)(a-b)
a.equals(new Character('a'))//返回true/false
a.toString() //返回String类
a.charValue() //返回char
a.isUpperCase(b) //返回b是否为大写字母
8.String 为不可变字符串;StringBuffer为可变字符串
String s = "abc";
s = s + "efg";
System.out.println(s);//abcefg
过程:s先被赋值为abc,再创建efg,再创建abcefg,将s指向abcefg。
浪费内存
StringBuffer dest = new StringBuffer("abc");
dest.length();//int 3
dest.charAt(0~length()-1)//char
dest.subString(1,2)//返回String类型
dest.indexof('c')//int,c的位置2
dest = dest+"abc";//error
dest.insert(dest.length(),"abc");
9.数字类Numeric
Byte/Short/Double/BigInteger/Float/BigDecimal/Integer/Long
Float c = new Float (1.0);
Double d = new Double(1.0);
c.euqals(d) //false
Float e = new Float(1.0);
c.equals(e) //true
10.数组:
char []a = new char[100];
public static void arraycopy(Object source,int srcIndex,Object dest,int destIndex,int length);
Sysytem.arraycopy(...);
1.接口 接口中所定义的方法都是抽象方法
Java语言学习笔记 CH3
1.数据类型 :原始类型,引用类型
原始类型 :char/numeric/array
numeric : integer/floating-point
integer : int/long/short/byte
float-point : float/double
引用类型:class/interface/array
2.float f = 0.1;//错,0.1默认是都爆了型
boolean b = 1;//错,boolean只能用true赋值
3.final已经赋值不能改变
final int i = 0;//正确
int final i = 0;//错误
Java语言学习 CH4
1.声明并没有创建对象 空引用
2.Point a = new Point(1,2);
Point b = new Point(1,2);
Point c = a;
a==b //flase
a==c //true
3.overload 重载
方法名相同,但参数不同的多个同名函数
注意: 1.参数不同的意思是参数类型、参数个数、参数顺序至少有一个不同
2.返回值和异常以及访问修饰符,不能作为重载的条件(因为对于匿名调用,会出现歧义,eg:void a ()和int a() ,如果调用a(),出现歧义)
3.main方法也是可以被重载的
override 覆盖
子类重写父类的方法,要求方法名和参数类型完全一样(参数不能是子类),返回值和异常比父类小或者相同(即为父类的子类),访问修饰符比父类大或者相同
注意:子类实例方法不能覆盖父类的静态方法;子类的静态方法也不能覆盖父类的实例方法(编译时报错),总结为方法不能交叉覆盖
hide 隐藏
父类和子类拥有相同名字的属性或者方法时,父类的同名的属性或者方法形式上不见了,实际是还是存在的
注意:当发生隐藏的时候,声明类型是什么类,就调用对应类的属性或者方法,而不会发生动态绑定
方法隐藏只有一种形式,就是父类和子类存在相同的静态方法
属性只能被隐藏,不能被覆盖
子类实例变量/静态变量可以隐藏父类的实例/静态变量,总结为变量可以交叉隐藏
隐藏和覆盖的区别:
被隐藏的属性,在子类被强制转换成父类后,访问的是父类中的属性
被覆盖的方法,在子类被强制转换成父类后,调用的还是子类自身的方法
因为覆盖是动态绑定,是受RTTI(run time type identification,运行时类型检查)约束的,隐藏不受RTTI约束,总结为RTTI只针对覆盖,不针对隐藏
特殊情况:
1.final修饰的属性可以被隐藏,但是不能被赋值,即不能用=来赋值,网上说final属性不能被修改,这个说法不准确,因为对于引用类型的变量用final修饰后,它只是不能被指向其他对象,但是可以改它自身的值,可以用ArrayList测试,final属性可以在运行的时候进行初始化,但是不能不出现初始化语句
2.final修饰的方法不能被覆盖,可以被重载
3.final修饰的类不能被继承
4.private 方法隐式添加了final
4.成员:类成员(static成员)+实例成员(非static成员),均包含变量和函数
5.Java的垃圾回收机制:没有引用的对象进行释放
6.Character :单一字符数值类
String :多个字符组成的不可变数据
StringBuffer :存储操作多个字符组成的可变数据
7.Character a = new Character('a');
a.compareTo(new Character('b'));
返回(int)(a-b)
a.equals(new Character('a'))//返回true/false
a.toString() //返回String类
a.charValue() //返回char
a.isUpperCase(b) //返回b是否为大写字母
8.String 为不可变字符串;StringBuffer为可变字符串
String s = "abc";
s = s + "efg";
System.out.println(s);//abcefg
过程:s先被赋值为abc,再创建efg,再创建abcefg,将s指向abcefg。
浪费内存
StringBuffer dest = new StringBuffer("abc");
dest.length();//int 3
dest.charAt(0~length()-1)//char
dest.subString(1,2)//返回String类型
dest.indexof('c')//int,c的位置2
dest = dest+"abc";//error
dest.insert(dest.length(),"abc");
9.数字类Numeric
Byte/Short/Double/BigInteger/Float/BigDecimal/Integer/Long
Float c = new Float (1.0);
Double d = new Double(1.0);
c.euqals(d) //false
Float e = new Float(1.0);
c.equals(e) //true
10.数组:
char []a = new char[100];
public static void arraycopy(Object source,int srcIndex,Object dest,int destIndex,int length);
Sysytem.arraycopy(...);