您的位置:首页 > 编程语言 > Java开发

JAVA重载和重写、内部类机制

2016-11-10 00:00 239 查看
#一、重载和重写
**重载 **

1、必须具有不同的参数列表;

2、可以有不责骂的返回类型,只要参数列表不同就可以了;

3、可以有不同的访问修饰符;

4、可以抛出不同的异常;

**重写 **

1、参数列表必须完全与被重写的方法相同,否则不能称其为重写而是重载。

2、返回的类型必须一直与被重写的方法的返回类型相同,否则不能称其为重写而是重载。

3、访问修饰符的限制一定要大于被重写方法的访问修饰符(public>protected>default>private)

4、重写方法一定不能抛出新的检查异常或者比被重写方法申明更加宽泛的检查型异常。例如:父类的一个方法申明了一个检查异常IOException,在重写这个方法是就不能抛出Exception,只能抛出IOException的子类异常,可以抛出非检查异常。

重载——有不同的参数列表(静态多态性)

重写——相同参数,不同实现(动态多态性)


#二、内部类机制
##常规内部类

1、常规内部类没有用static修饰且定义在在外部类类体中

2、常规内部类中的方法可以直接使用外部类的实例变量和实例方法

3、在常规内部类中可以直接用内部类创建对象

public class MyOuter {
private int x = 100;
// 创建内部类
class MyInner {
private String y = "Hello!";
public void innerMethod() {
System.out.println("内部类中 String =" + y);
System.out.println("外部类中的x =" + x);// 直接访问外部类中的实例变量x
outerMethod();
System.out.println("x is" + MyOuter.this.x);
}
}
public void outerMethod() {
x++;
}
public void makeInner() {
//在外部类方法中创建内部类实例
MyInner in = new MyInner();
}
/**
* @param args
*/
public static void main(String[] args) {
MyOuter mo = new MyOuter();
// 使用外部类构造方法创建mo对象
MyOuter.MyInner inner = mo.new MyInner();//常规内部类需要通过外部类的实例才能创建对象,与实例变量需要通过对象来访问相似
// 创建inner对象
inner.innerMethod();
// TODO Auto-generated method stub
}
}

//输出结果
内部类中 String =Hello!
外部类中的x =100
x is101

##静态内部类

1、与类的其他成员相似,用static修饰内部类;

2、静态内部类与静态内部方法相似,只能访问外部类的static成员,不能直接访问外部类的实例变量,与实例方法,只有通过对象引用才能访问。

3、由于static内部类不具有任何对外部类实例的引用,因此static内部类中不能使用this关键字来访问外部类中的实例成员,但是可以访问外部类中的static成员。

package com.m.ou;
public class MyOuter {
public static int x=100;
public static class MyInner{
private String y="Hello!";
public void innerMethod(){
System.out.println("x="+x);
System.out.println("y="+y);
}
}
/**
* @param args
*/
public static void main(String[] args) {
MyOuter.MyInner si=new MyOuter.MyInner();//静态内部类不通过外部实例就可以创建对象;与类变量可以通过类名访问相似
si.innerMethod();
// TODO Auto-generated method stub
}
}

//输出结果
x=100
y=Hello!

##局部内部类

1、在方法体或语句块(包括方法、构造方法、局部块或静态初始化块)内部定义的类;

2、局部内部类不能加任何访问修饰符,因为它只对局部块有效;

3、局部内部类只在方法体中有效,和定义的局部变量一样,在定义的方法体外不能创建局部内部类的对象;

4、在方法内部定义类时,应注意以下问题:

1)方法定义局部内部类同方法定义局部变量一样,不能使用private、protected、public等访问修饰说明符修饰,也不能使用static修饰,但可以使用final和 abstract修饰;

2)方法中的内部类可以访问外部类成员。对于方法的参数和局部变量,必须有final修饰才可以访问。

3)static方法中定义的内部类可以访问外部类定义的static成员。

public class Jubu {
private int size=5,y=7;
public Object makeInner(int localVar){
final int finalLocalVar=localVar;
//创建内部类,该类只在makeInner()方法有效,就像局部变量一样。在方法体外部不能创建MyInner类的对象
class MyInner{
int y=4;
public String toString(){
return "OuterSize:"+size+
"\nfinalLocalVar"+" "+"this.y="+this.y;
}
}
return new MyInner();
}
}
class Main{ /**
* @param args
*/
public static void main(String[] args) {

Object obj=new Jubu().makeInner(47);//创建Jubu对象obj,并调用它的makeInner()方法,该方法返回一个
//该方法返回一个MyInner类型的的对象obj,然后调用其同toString方法。
System.out.println(obj.toString());
// TODO Auto-generated method stub
}
}
//输出结果
OuterSize:5
finalLocalVar this.y=4

##匿名内部类

定义类的最终目的是创建一个类的实例,但是如果某个类的实例只是用一次,则可以将类的定义与类的创建,放到与一起完成,或者说在定义类的同时就创建一个类。 以这种方法定义的没有名字的类成为匿名内部类;

1、匿名内部类可以继承一个类或实现一个接口,这里的ClassOrInterfaceName是匿名内部类所继承的类名或实现的接口名。但匿名内部类不能同时实现一个接口和继承一个类,也不能实现多个接口。如果实现了一个接口,该类是Object类的直接子类,匿名类继承一个类或实现一个接口,不需要extends和implements关键字。

2、由于匿名内部类没有名称,所以类体中不能定义构造方法,由于不知道类名也不能使用关键字来创建该类的实例。实际上匿名内部类的定义、构造、和第一次使用都发生在同样一个地方。此外,上式是一个表达式,返回的是一个对象的引用,所以可以直接使用或将其复制给一个对象变量。

//定义格式
new ClassOrInterfaceName(){
/*类体*/
}

TypeName obj=new Name(){
/*此处为类体*/
}

//也可以将构造的对象作为调用的参数
someMethod(new Name(){
/*此处为类体*/  });

//测试
public class NiMing {
private int size=5;
public Object makeInner(int localVar){
final int finalLocalVar=localVar;
return new Object(){
//使用匿名内部类
public String toString(){
return "OuterSize="+size+"\nfinalLocalVar="+finalLocalVar;
}
};
}
/**
* @param args
*/
public static void main(String args[])
{
Object obj=new NiMing().makeInner(47);
System.out.println(obj.toString());
}
}

//返回结果
OuterSize=5
finalLocalVar=47

参考文献:

http://blog.csdn.net/qq435757399/article/details/7037007
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: