面向对象(类,对象,方法)
首先来说下抽象类,说到抽象类,就不得不提一下接口了,它们有什么区别呢?
抽象类:如果一个类中没有包含足够的信息来描绘一个具体的对象,这样的类就是抽象类.它和接口有什么区别呢?
类可以实现(implements)多个接口,而只能继承一个类.
抽象类特点:1.被abstruct修饰
2.抽象类可以没有抽象方法,但是有抽象方法的类一定是抽象类
3.抽象类不能被自己实例化,必须用一个子类来继承这个抽象类,重写当中的方法
4.一个类继承自一个抽象类,要么这个类也是一个抽象类,要么这个类重写了抽象类的所有抽象方法
抽象类能不能有构造方法?
答案是可以的,但是没有任何意义,因为抽象类是不能被自己实例化的.必须通过子类继承父类,通过构造函数重写构造方法.
匿名内部类:其实就是一个继承了类或者实现了接口的子类匿名对象.
匿名内部类特点:要有继承或者实现关系.
匿名对象:就是没有名字的对象
匿名对象的应用场景: 只调用一次的时候使用匿名对象,这样可以起到节省代码的作用;那么调用多次的时候不要使用这个,因为匿名对象在调用一次之后就会被当做垃圾回收掉(垃圾回收器).
附上一个匿名对象的代码具体来看:
class Car {
public static void main(String[] args) {
Car c1 = new Car();//创建有名字的对象
c1.run();
c1.run();
new Car().run();//匿名对象调用方法
//new Car().run();//匿名对象只适合对方法的一次调用,因为调用多次就会产生多个对象,不如用有名字的对象
new Car().color = "red";
new Car().num = 4;
new Car().run();
}
}
class Car {
String color; //颜色
int num; //轮胎数
public void run() {
System.out.println(color + "..." + num);
}
}
直接new一个匿名对象调用方法,这个就叫匿名对象,没有名字,直接调用方法,但是就只调用一次就被清理掉了.和匿名内部类一样,匿名内部类也是在只调用一次的时候使用,这样非常的节省代码,而且占用的资源少,高效
重写和重载的区别?
重写(overwrite):父类已经有了一个方法,而子类需要有特殊的需求,而重写了父类的这个方法,方法名,参数列表和父类相同,但是方法体是不相同,这样叫做重写.
重载(override):一个类调用另一个类的方法的时候,另一个类中有两种或两种以上的方法,他们的方法名都是相同的,但是参数列表不相同,那么这个类在调用的时候随着参数的不同,会调用不同的方法,就是根据另一个类方法的参数列表来区分的,这些方法就属于重载.
内部类能不能访问外部变量?
答案是可以的,因为外部变量属于全局变量,随时随地可以被调用.
外部类能不能访问内部变量?
答案是不可以的.因为内部变量属于局部变量,它是随着方法的调用而调用,随着方法的消失而消失的,而外部类想调用的时候方法还没有调用,而等到调用完后内部变量随着方法的消失而消失了.
那么说到这里,如果外部类就想要调用内部变量应该怎么做呢?
给内部变量用final修饰,这样内部变量就会成为成员变量,随时随地都可以调用啦.
说到final,我们来说一下final,finally,finalize的区别
final:最终的意思.
1.被final修饰的类是不能被继承的
2.被final修饰的方法是不能被重写的
3.被final修饰的变量是常量,只能被赋值一次
finally:在异常机制当中使用(try catch)
try{
System.out.println(111);
}catch(Exception a) {
System.out.println(222);
}finally {
System.out.println("是否执行");
}
用一个简单的try catch finally例子说明一下,这个属于编译时异常,后面博客会有讲到.finally是要和try catch一起使用的,并且finally是肯定要被执行一次的
注意:这里需要多提的一点是,finally和return同时出现的时候会先执行哪条语句?
答案是先执行finally,后执行return,记得,和return想必,肯定是最后执行,因为执行完return,这个代码就会执行完毕.
finalize:它属于object类中的方法,所有的子类通过重写这个方法,来完成垃圾清理工作
构造方法有什么特点?
特点:构造方法名必须与类名相同,还有,构造方法是没有返回值的(或者说与返回值无关).
构造方法是用来干嘛的,有什么作用?
是子类对象用来初始化父类数据的.